"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var cg_teams_leveling_exports = {}; __export(cg_teams_leveling_exports, { addPokemon: () => addPokemon, dbSetupPromise: () => dbSetupPromise, handlers: () => handlers, incrementLosses: () => incrementLosses, incrementWins: () => incrementWins }); module.exports = __toCommonJS(cg_teams_leveling_exports); var import_lib = require("../../lib"); let addPokemon = null; let incrementWins = null; let incrementLosses = null; let dbSetupPromise = null; async function setupDatabase(database) { await database.runFile("./databases/schemas/battlestats.sql"); addPokemon = await database.prepare( "INSERT OR IGNORE INTO gen9computergeneratedteams (species_id, wins, losses, level) VALUES (?, 0, 0, ?)" ); incrementWins = await database.prepare( "UPDATE gen9computergeneratedteams SET wins = wins + 1 WHERE species_id = ?" ); incrementLosses = await database.prepare( "UPDATE gen9computergeneratedteams SET losses = losses + 1 WHERE species_id = ?" ); } if (Config.usesqlite && Config.usesqliteleveling) { const database = (0, import_lib.SQL)(module, { file: "./databases/battlestats.db" }); dbSetupPromise = setupDatabase(database); } async function updateStats(battle, winner) { if (!incrementWins || !incrementLosses) await dbSetupPromise; if (battle.rated < 1e3 || toID(battle.format) !== "gen9computergeneratedteams") return; const p1 = Users.get(battle.p1.name); const p2 = Users.get(battle.p2.name); if (!p1 || !p2) return; const p1team = await battle.getTeam(p1); const p2team = await battle.getTeam(p2); if (!p1team || !p2team) return; let loserTeam, winnerTeam; if (winner === p1.id) { loserTeam = p2team; winnerTeam = p1team; } else { loserTeam = p1team; winnerTeam = p2team; } for (const species of winnerTeam) { await addPokemon?.run([toID(species.species), species.level]); await incrementWins?.run([toID(species.species)]); } for (const species of loserTeam) { await addPokemon?.run([toID(species.species), species.level]); await incrementLosses?.run([toID(species.species)]); } } const handlers = { onBattleEnd(battle, winner) { if (!Config.usesqlite || !Config.usesqliteleveling) return; void updateStats(battle, winner); } }; //# sourceMappingURL=cg-teams-leveling.js.map