diff --git a/dist/index.js b/dist/index.js deleted file mode 100644 index b288507..0000000 --- a/dist/index.js +++ /dev/null @@ -1,2 +0,0 @@ -(()=>{"use strict";var e=function(e){var t=document.querySelector("#whoChoosesParagraph");3===e.pokemons.length?t.textContent="Wait for the game to start...":t.textContent=e.name+" chooses 1 pokemon"},t=function(){function e(e,t,n,o,r,a,c){this._name=e,this._image=t,this._maxHP=n,this._currentHP=n,this._attackPoints=o,this._defensePoints=r,this._types=a,this._moves=c}return Object.defineProperty(e.prototype,"name",{get:function(){return this._name},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"image",{get:function(){return this._image},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"currentHP",{get:function(){return this._currentHP},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"maxHP",{get:function(){return this._maxHP},enumerable:!1,configurable:!0}),e.prototype.subtractHP=function(e){var t=this._currentHP-e;t<0&&(this._currentHP=0),this._currentHP=t},e.prototype.heal=function(){this._currentHP=this._maxHP},Object.defineProperty(e.prototype,"attackPoints",{get:function(){return this._attackPoints},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"defensePoints",{get:function(){return this._defensePoints},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"types",{get:function(){return this._types},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"moves",{get:function(){return this._moves},enumerable:!1,configurable:!0}),e.prototype.isAlive=function(){return this._currentHP>0},e}(),n=function(){function e(e){this._pokemons=[];for(var n=0,o=e;ne.alivePokemons.length-1;n--)t[n].classList.add("disabledPokemon")},n=Array.from(document.querySelectorAll("#fight-page-player1 .pokeballWithPokemon")),o=Array.from(document.querySelectorAll("#fight-page-player2 .pokeballWithPokemon"));t(e.playerOne,n),t(e.playerTwo,o)},u=function(e,t,n,o){e.addEventListener("click",(function(u){console.log(e.innerText+" used!"),o&&(o(n,u),function(e,t,n){var o=document.querySelector(".gameLogs"),r=document.createElement("p"),a=document.createTextNode("No move found"),c=e.currentPlayer.getActivePokemon.name,i=n.currentTarget.textContent,u=e.currentPlayer.name;switch(console.log(),t){case p:a.nodeValue=u+": "+c+" used "+i+"!";break;case m:a.nodeValue=u+" changed Pokemon: "+c+" comes into play!";break;case y:a.nodeValue=u+" used mango: "+c+" is healed!";break;default:console.log("No move found")}console.log(r),r.append(a),o.insertBefore(r,o.firstChild)}(n,o,u),r(n),c(n.playerOne,n.playerTwo),i(n),n.switchPlayer(),a(n)),setTimeout((function(){n.generateAttackButtons(),n.generateSwitchButtons(),n.generateActionButtons()}),1e3),l(t)}))},s=function(e){for(var t=0;t\n
'+a.getActivePokemon.moves[1].moveName+'
\n
back
',e=this,t=document.querySelector("#attackButtonOne"),n=document.querySelector("#attackButtonTwo"),o=document.getElementsByClassName("battleButton"),r=document.querySelector("#backButton"),s(o),u(t,o,e,p),u(n,o,e,p),u(r,o,e)},e.prototype.generateSwitchButtons=function(){var e,t,n,o,r,a=this.currentPlayer;console.log("Switch choose modal"),document.querySelector("#actionModals").innerHTML='\n
'+a.notActivePokemons[0].name+'
\n
'+a.notActivePokemons[1].name+'
\n
back
',e=this,t=document.querySelector("#switchButtonOne"),n=document.querySelector("#switchButtonTwo"),o=document.getElementsByClassName("battleButton"),r=document.querySelector("#backButton"),s(o),u(t,o,e,m),u(n,o,e,m),u(r,o,e)},e}(),h=function(e,t){e.pokemons.length<3||t.pokemons.length<3||function(e,t,n){var o=new d(e,t);setTimeout((function(){return e=n,t=o,u=document.querySelector("#fight-page-template"),e.innerHTML=u.innerHTML,function(e){var t=document.querySelector("#fight-page-player1-name"),n=document.querySelector("#fight-page-player2-name");t.textContent=e.playerOne.name,n.textContent=e.playerTwo.name}(t),a(t),r(t),c(t.playerOne,t.playerTwo),i(t),void t.generateActionButtons();var e,t,u}),2e3)}(e,t,document.querySelector("#app"))},f=function(t,r){var a=t;!function(e,t){document.querySelector("#choosePagePlayer1Name").textContent=e.name,document.querySelector("#choosePagePlayer2Name").textContent=t.name}(t,r),e(a),function(t,r,a){var c=o.x,i=new n(c);Array.from(document.querySelectorAll("#pokemonList img")).forEach((function(n){return n.addEventListener("click",(function(n){3!==a.pokemons.length&&(function(e,t,n){var o=e.target,r=o.id,a=t.getPokemonByName(r);n.addPokemon(a),o.style.cursor="default",o.style.filter="grayscale(100%)"}(n,i,a),function(e,t){var n=t===e?Array.from(document.querySelectorAll("#choosePagePlayer1 img")):Array.from(document.querySelectorAll("#choosePagePlayer2 img")),o=t.pokemons[t.pokemons.length-1].name.toLowerCase();n[t.pokemons.length-1].setAttribute("src","./assets/"+o+".png")}(t,a),e(a=a===t?r:t),h(t,r))}),{once:!0})}))}(t,r,a)},g=function(){function e(e,t){if(e.length>8)throw new Error("Too long name");if(t.length>3)throw new Error("Wrong number of pokemons");this._name=e,this._pokemons=t,this._indexOfActivePokemon=0,this._hasMango=!0}return Object.defineProperty(e.prototype,"name",{get:function(){return this._name},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"pokemons",{get:function(){return this._pokemons},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"indexOfActivePokemon",{set:function(e){this._indexOfActivePokemon=e},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"getActivePokemon",{get:function(){return this._pokemons[this._indexOfActivePokemon]},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"alivePokemons",{get:function(){return this.pokemons.filter((function(e){return e.isAlive()}))},enumerable:!1,configurable:!0}),e.prototype.useMango=function(){if(!this._hasMango)throw new Error("You cannot use mango. You use all mangos");this._hasMango=!1,this.getActivePokemon.heal()},Object.defineProperty(e.prototype,"hasMango",{get:function(){return this._hasMango},enumerable:!1,configurable:!0}),e.prototype.addPokemon=function(e){this._pokemons.push(e)},Object.defineProperty(e.prototype,"notActivePokemons",{get:function(){var e=this;return this.pokemons.filter((function(t){return t.name!==e.getActivePokemon.name}))},enumerable:!1,configurable:!0}),e}(),b=function(e,t,n){e.value.length>0&&t.value.length>0&&e.value.length<=8&&t.value.length<=8?(n.className="button-enabled",n.disabled=!1):(n.className="button-disabled",n.disabled=!0)};setTimeout((function(){var e,t,n,o,r,a,c,i,u,s=document.querySelector("#app");e=s,t=document.querySelector("#starting-page-template"),e.innerHTML=t.innerHTML,function(e){var t=document.querySelector("#info-modal-template");e.innerHTML+=t.innerHTML}(s),n=document.querySelector("#enter-player1-name"),o=document.querySelector("#enter-player2-name"),r=document.querySelector("#start-game-button"),n.addEventListener("keyup",(function(){b(n,o,r)})),o.addEventListener("keyup",(function(){b(n,o,r)})),i=document.querySelector("#how-to-play-button"),u=document.querySelector("#info-modal-screen"),i.addEventListener("click",(function(){u.style.display="flex"})),null==(c=(a=u).querySelector(".exitButton"))||c.addEventListener("click",(function(){a.style.display="none"})),function(e){var t=document.querySelector("#start-game-button");null==t||t.addEventListener("click",(function(){var t=document.querySelector("#enter-player1-name").value,n=document.querySelector("#enter-player2-name").value,o=document.querySelector("#choose-page-template");e.innerHTML=o.innerHTML,f(new g(t,[]),new g(n,[]))}))}(s)}),2e3)})(); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://coderscamp2020.project.typescript.pokemonfight/./src/modalPopUpFunctions.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/createActivePlayerName.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/pokemonClass.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/pokemonFactory.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/createActivePokemon.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/createActivePlayer.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/createHPBars.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/createFightPagePokeballs.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/buttonsEventListeners.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/updateMovesList.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/gameHandlerClass.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/startGameIfReady.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/startBattle.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/fightPage/renderFightPage.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/choosePokemonsPage.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/createPlayerNames.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/createPokemons.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/addChosenPokemon.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/choosePokemonsPage/createPokeballs.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/playerClass.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/activateStart.ts","webpack://coderscamp2020.project.typescript.pokemonfight/./src/index.ts"],"names":["createActivePlayerName","activePlayer","whoChoosesPokemonText","document","querySelector","pokemons","length","textContent","name","image","maxHP","attackPoints","defensePoints","types","moves","this","_name","_image","_maxHP","_currentHP","_attackPoints","_defensePoints","_types","_moves","subtractHP","pointsToSubtract","newHP","heal","isAlive","pokeData","_pokemons","pokemon","pokeImg","pokeMoves","reduce","tab","move","push","moveName","moveType","type","pokeTypes","map","v","pokemonObject","Pokemon","_capitalize","stats","hp","attack","defense","getPokemonByName","find","toLowerCase","undefined","Error","str","charAt","toUpperCase","slice","createActivePokemon","gameHandler","playerOneActivePokemonImageArea","playerTwoActivePokemonImageArea","playerOneActivePokemonNameArea","playerTwoActivePokemonNameArea","createPokemon","player","imageArea","nameArea","pokemonName","getActivePokemon","setAttribute","playerOne","playerTwo","createActivePlayer","currentPlayer","playerOneUnderlineArea","playerTwoUnderlineArea","classList","remove","add","createHPBars","createBar","HPBar","HPInPercent","currentHP","console","log","style","width","HPClassList","playerOneHPBar","playerTwoHPBar","createFightPagePokeballs","changeClassOfDisabledPokemons","playerPokeballs","i","alivePokemons","playerOnePokeballs","Array","from","querySelectorAll","playerTwoPokeballs","magicFunction","button","buttons","functionToCall","addEventListener","e","innerText","calledFunction","event","moveList","newMove","createElement","newMoveText","createTextNode","buttonContent","currentTarget","playerName","nodeValue","switchPoke","eatMango","append","insertBefore","firstChild","updateMovesList","switchPlayer","setTimeout","generateAttackButtons","generateSwitchButtons","generateActionButtons","animationButtonsExit","animationButtonsEntry","animation","animationDelay","nameOfChosenPokemon","switchPokemon","mangoButton","mango","useMango","innerHTML","_playerOne","_playerTwo","_currentPlayer","didPlayerLoose","isGameFinished","getWinner","indexOfActivePokemon","findIndex","battleButtons","attackButton","switchButton","getElementsByClassName","hasMango","attackButtonOne","attackButtonTwo","backButton","switchButtonOne","switchButtonTwo","notActivePokemons","startGameIfReady","app","game","GameHandler","appDiv","fightPage","playerOneName","playerTwoName","createPlayerFightNames","startBattle","createChoosePage","createPlayerNames","pokemonFactory","PokemonFactory","forEach","pokemonImage","factory","clickedPokemon","target","id","newPokemonObject","addPokemon","cursor","filter","addChosenPokemon","playerLastPokemonName","createPokeballs","once","createPokemons","_indexOfActivePokemon","_hasMango","numOfActivePokemon","activateStart","name1Input","name2Input","startButton","value","className","disabled","startingPage","player1NameInput","player2NameInput","screenToDisplay","exitButton","howToPlayButton","infoModal","renderHowToPlayModal","display","playButton","choosePokemonScreen","Player","renderChoosePokemonScreen"],"mappings":"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","file":"index.js","sourcesContent":["export const showModal = (\r\n  screenToDisplay: HTMLDivElement,\r\n  startingPosition: string\r\n) => {\r\n  screenToDisplay.style.display = startingPosition;\r\n};\r\n\r\nexport const hideModal = (screenToDisplay: HTMLDivElement) => {\r\n  const exitButton = screenToDisplay.querySelector(\".exitButton\");\r\n  exitButton?.addEventListener(\"click\", () => {\r\n    screenToDisplay.style.display = \"none\";\r\n  });\r\n};\r\n","import { Player } from \"../playerClass\";\r\n\r\nexport const createActivePlayerName = (activePlayer: Player) => {\r\n  let whoChoosesPokemonText = document.querySelector(\"#whoChoosesParagraph\")!;\r\n  activePlayer.pokemons.length === 3\r\n    ? (whoChoosesPokemonText.textContent = \"Wait for the game to start...\")\r\n    : (whoChoosesPokemonText.textContent = `${activePlayer.name} chooses 1 pokemon`);\r\n};\r\n","export type PokemonType =\r\n  | \"grass\"\r\n  | \"poison\"\r\n  | \"fire\"\r\n  | \"water\"\r\n  | \"bug\"\r\n  | \"normal\"\r\n  | \"flying\"\r\n  | \"electric\"\r\n  | \"ground\"\r\n  | \"fairy\"\r\n  | \"psychic\"\r\n  | \"fighting\"\r\n  | \"rock\";\r\n\r\nexport class Pokemon {\r\n\r\n  readonly _name: string;\r\n  readonly _image: string;\r\n  readonly _maxHP: number;\r\n  private _currentHP: number;\r\n  readonly _attackPoints: number;\r\n  readonly _defensePoints: number;\r\n  readonly _types: PokemonType[];\r\n  readonly _moves: { moveName: string; moveType: PokemonType }[];\r\n\r\n  constructor(name: string, image: string, maxHP: number, attackPoints: number,\r\n    defensePoints: number, types: PokemonType[], moves: { moveName: string; moveType: PokemonType }[]) {\r\n\r\n    this._name = name;\r\n    this._image = image;\r\n    this._maxHP = maxHP;\r\n    this._currentHP = maxHP;\r\n    this._attackPoints = attackPoints;\r\n    this._defensePoints = defensePoints;\r\n    this._types = types;\r\n    this._moves = moves;\r\n  }\r\n\r\n\r\n  get name() {\r\n    return this._name;\r\n  }\r\n\r\n  get image() {\r\n    return this._image;\r\n  }\r\n\r\n  get currentHP() {\r\n    return this._currentHP;\r\n  }\r\n\r\n  get maxHP() {\r\n    return this._maxHP;\r\n  }\r\n\r\n  subtractHP(pointsToSubtract: number): void {\r\n    const newHP = this._currentHP - pointsToSubtract;\r\n    if (newHP < 0) {\r\n      this._currentHP = 0;\r\n    }\r\n    this._currentHP = newHP;\r\n  }\r\n\r\n  heal(): void {\r\n    this._currentHP = this._maxHP;\r\n  }\r\n\r\n  get attackPoints() {\r\n    return this._attackPoints;\r\n  }\r\n\r\n  get defensePoints() {\r\n    return this._defensePoints;\r\n  }\r\n\r\n  get types() {\r\n    return this._types;\r\n  }\r\n\r\n  get moves() {\r\n    return this._moves;\r\n  }\r\n\r\n  isAlive(): boolean {\r\n    return this._currentHP > 0;\r\n  }\r\n}\r\n","import { Pokemon } from \"./pokemonClass\"\r\nimport { PokemonType } from \"./pokemonClass\"\r\n\r\n\r\nexport class PokemonFactory {\r\n    readonly _pokemons: Pokemon[];\r\n\r\n    constructor(pokeData: {\r\n        name: string; types: string[];\r\n        stats: { hp: number; attack: number; defense: number; };\r\n        moves: { name: string; accuracy: number; power: number; type: string; }[]\r\n    }[]) {\r\n        this._pokemons = [];\r\n\r\n        for (let pokemon of pokeData) {\r\n\r\n            const pokeImg = \"../assets/\" + pokemon.name + \".png\"\r\n\r\n            const pokeMoves = pokemon.moves.reduce( (tab, move) => {\r\n                tab.push({moveName: move.name, moveType: move.type as PokemonType})\r\n                return tab\r\n                }, [] as {moveName: string, moveType: PokemonType}[])\r\n\r\n            const pokeTypes: PokemonType[] = pokemon.types.map(v => v as PokemonType)\r\n\r\n            const pokemonObject = new Pokemon(this._capitalize(pokemon.name), pokeImg, \r\n                pokemon.stats.hp, pokemon.stats.attack, pokemon.stats.defense,\r\n                pokeTypes, pokeMoves)\r\n\r\n            this._pokemons.push(pokemonObject)\r\n        }\r\n    }\r\n\r\n    get pokemons(): Pokemon[] {\r\n        return this._pokemons\r\n    }\r\n\r\n    getPokemonByName(name: string): Pokemon {\r\n        const pokemon = this._pokemons.find( pokemon => pokemon.name.toLowerCase() === name.toLowerCase());\r\n        if (pokemon === undefined) {\r\n            throw new Error(`Pokemon ${name} is not found in the pokemon factory`)\r\n        }\r\n        return pokemon\r\n    }\r\n\r\n    _capitalize(str: string): string {\r\n        return str.charAt(0).toUpperCase() + str.slice(1);\r\n      }\r\n}\r\n\r\n","import { Player } from \"../playerClass\";\r\nimport { GameHandler } from \"../gameHandlerClass\";\r\n\r\nexport const createActivePokemon = (gameHandler: GameHandler) => {\r\n  const playerOneActivePokemonImageArea = document.querySelector(\r\n    \"#pokemon-image-player1\"\r\n  ) as HTMLImageElement;\r\n  const playerTwoActivePokemonImageArea = document.querySelector(\r\n    \"#pokemon-image-player2\"\r\n  ) as HTMLImageElement;\r\n  const playerOneActivePokemonNameArea = document.querySelector(\r\n    \"#pokemon-name-player1\"\r\n  ) as HTMLHeadingElement;\r\n  const playerTwoActivePokemonNameArea = document.querySelector(\r\n    \"#pokemon-name-player2\"\r\n  ) as HTMLHeadingElement;\r\n  const createPokemon = (\r\n    player: Player,\r\n    imageArea: HTMLImageElement,\r\n    nameArea: HTMLHeadingElement\r\n  ) => {\r\n    const pokemonName = player.getActivePokemon.name;\r\n    imageArea.setAttribute(\"src\", `./assets/${pokemonName.toLowerCase()}.png`);\r\n    nameArea.textContent = pokemonName;\r\n  };\r\n  createPokemon(\r\n    gameHandler.playerOne,\r\n    playerOneActivePokemonImageArea,\r\n    playerOneActivePokemonNameArea\r\n  );\r\n  createPokemon(\r\n    gameHandler.playerTwo,\r\n    playerTwoActivePokemonImageArea,\r\n    playerTwoActivePokemonNameArea\r\n  );\r\n};\r\n","import { GameHandler } from \"../gameHandlerClass\";\r\n\r\nexport const createActivePlayer = (gameHandler: GameHandler) => {\r\n  const activePlayerArea = document.querySelector(\r\n    \"#active-player-info\"\r\n  ) as HTMLDivElement;\r\n  activePlayerArea.textContent = `${gameHandler.currentPlayer.name} now is your turn. Get the revenge!`;\r\n  const playerOneUnderlineArea = document.querySelector(\"#fight-page-player1\");\r\n  const playerTwoUnderlineArea = document.querySelector(\"#fight-page-player2\");\r\n  if (gameHandler.currentPlayer === gameHandler.playerOne) {\r\n    playerTwoUnderlineArea?.classList.remove(\"activePlayer\");\r\n    playerOneUnderlineArea?.classList.add(\"activePlayer\");\r\n  } else {\r\n    playerOneUnderlineArea?.classList.remove(\"activePlayer\");\r\n    playerTwoUnderlineArea?.classList.add(\"activePlayer\");\r\n  }\r\n};\r\n","import { Player } from \"../playerClass\";\r\n\r\nexport const createHPBars = (playerOne: Player, playerTwo: Player) => {\r\n  const createBar = (player: Player, HPBar: HTMLDivElement) => {\r\n    const maxHP = player.getActivePokemon.maxHP;\r\n    const currentHP = player.getActivePokemon.currentHP;\r\n    const HPInPercent = (currentHP / maxHP) * 100;\r\n    console.log(HPInPercent);\r\n    HPBar.style.width = `${HPInPercent}%`;\r\n    let HPClassList = HPBar.classList;\r\n    if (HPInPercent < 20) {\r\n      HPClassList.remove(\"hpBarHighLevel\");\r\n      HPClassList.add(\"hpBarLowLevel\");\r\n    } else {\r\n      HPClassList.remove(\"hpBarLowLevel\");\r\n      HPClassList.add(\"hpBarHighLevel\");\r\n    }\r\n  };\r\n  const playerOneHPBar = document.querySelector(\r\n    \"#hp-bar-player1\"\r\n  ) as HTMLDivElement;\r\n  const playerTwoHPBar = document.querySelector(\r\n    \"#hp-bar-player2\"\r\n  ) as HTMLDivElement;\r\n  createBar(playerOne, playerOneHPBar);\r\n  createBar(playerTwo, playerTwoHPBar);\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { GameHandler } from \"../gameHandlerClass\";\r\n\r\nexport const createFightPagePokeballs = (gameHandler: GameHandler) => {\r\n  const changeClassOfDisabledPokemons = (\r\n    player: Player,\r\n    playerPokeballs: HTMLImageElement[]\r\n  ) => {\r\n    for (let i = 2; i > player.alivePokemons.length - 1; i--) {\r\n      playerPokeballs[i].classList.add(\"disabledPokemon\");\r\n    }\r\n  };\r\n  const playerOnePokeballs = Array.from(\r\n    document.querySelectorAll(\"#fight-page-player1 .pokeballWithPokemon\")\r\n  ) as HTMLImageElement[];\r\n  const playerTwoPokeballs = Array.from(\r\n    document.querySelectorAll(\"#fight-page-player2 .pokeballWithPokemon\")\r\n  ) as HTMLImageElement[];\r\n  changeClassOfDisabledPokemons(gameHandler.playerOne, playerOnePokeballs);\r\n  changeClassOfDisabledPokemons(gameHandler.playerTwo, playerTwoPokeballs);\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { GameHandler } from \"../gameHandlerClass\";\r\nimport { createActivePokemon } from \"./createActivePokemon\";\r\nimport { createActivePlayer } from \"./createActivePlayer\";\r\nimport { createHPBars } from \"./createHPBars\";\r\nimport { createFightPagePokeballs } from \"./createFightPagePokeballs\";\r\nimport { updateMovesList } from \"./updateMovesList\";\r\n\r\nexport const actionsButtonEventListener = (\r\n  //player: Player,\r\n  gameHandler: GameHandler\r\n) => {\r\n  const battleButtons = document.getElementsByClassName(\r\n    \"battleButton\"\r\n  )! as HTMLCollectionOf<HTMLElement>;\r\n  const attackButton = document.querySelector(\r\n    \"#attackButton\"\r\n  )! as HTMLDivElement;\r\n  const switchButton = document.querySelector(\r\n    \"#switchButton\"\r\n  )! as HTMLDivElement;\r\n  const mangoButton = document.querySelector(\"#mangoButton\")! as HTMLDivElement;\r\n  const mango = document.querySelector(\"#mango\")! as HTMLDivElement;\r\n\r\n  animationButtonsEntry(battleButtons);\r\n\r\n  attackButton.addEventListener(\"click\", () => {\r\n    animationButtonsExit(battleButtons);\r\n    setTimeout(() => {\r\n      gameHandler.generateAttackButtons();\r\n    }, 1000);\r\n  });\r\n  switchButton.addEventListener(\"click\", () => {\r\n    animationButtonsExit(battleButtons);\r\n    setTimeout(() => {\r\n      gameHandler.generateSwitchButtons();\r\n    }, 1000);\r\n  });\r\n\r\n  if (gameHandler.currentPlayer.hasMango) {\r\n    magicFunction(mangoButton, battleButtons, gameHandler, eatMango);\r\n  } else {\r\n    mango.innerHTML = \"0\";\r\n    mangoButton.classList.add(\"disabledButton\");\r\n  }\r\n};\r\n\r\nexport const attacksButtonEventListener = (gameHandler: GameHandler) => {\r\n  const attackButtonOne = document.querySelector(\r\n    \"#attackButtonOne\"\r\n  )! as HTMLDivElement;\r\n  const attackButtonTwo = document.querySelector(\r\n    \"#attackButtonTwo\"\r\n  )! as HTMLDivElement;\r\n  const battleButtons = document.getElementsByClassName(\r\n    \"battleButton\"\r\n  )! as HTMLCollectionOf<HTMLElement>;\r\n  const backButton = document.querySelector(\"#backButton\")! as HTMLDivElement;\r\n\r\n  animationButtonsEntry(battleButtons);\r\n  magicFunction(attackButtonOne, battleButtons, gameHandler, attack);\r\n  magicFunction(attackButtonTwo, battleButtons, gameHandler, attack);\r\n  magicFunction(backButton, battleButtons, gameHandler);\r\n};\r\n\r\nexport const switchButtonEventListener = (gameHandler: GameHandler) => {\r\n  const switchButtonOne = document.querySelector(\r\n    \"#switchButtonOne\"\r\n  )! as HTMLDivElement;\r\n  const switchButtonTwo = document.querySelector(\r\n    \"#switchButtonTwo\"\r\n  )! as HTMLDivElement;\r\n  const battleButtons = document.getElementsByClassName(\r\n    \"battleButton\"\r\n  )! as HTMLCollectionOf<HTMLElement>;\r\n  const backButton = document.querySelector(\"#backButton\")! as HTMLDivElement;\r\n\r\n  animationButtonsEntry(battleButtons);\r\n\r\n  magicFunction(switchButtonOne, battleButtons, gameHandler, switchPoke);\r\n  magicFunction(switchButtonTwo, battleButtons, gameHandler, switchPoke);\r\n  magicFunction(backButton, battleButtons, gameHandler);\r\n};\r\n\r\nconst magicFunction = (\r\n  button: HTMLDivElement,\r\n  buttons: HTMLCollectionOf<HTMLElement>,\r\n  gameHandler: GameHandler,\r\n  functionToCall?: any\r\n) => {\r\n  button.addEventListener(\"click\", (e) => {\r\n    console.log(`${button.innerText} used!`);\r\n    if (functionToCall) {\r\n      functionToCall(gameHandler, e);\r\n      updateMovesList(gameHandler, functionToCall, e);\r\n      createActivePokemon(gameHandler);\r\n      createHPBars(gameHandler.playerOne, gameHandler.playerTwo);\r\n      createFightPagePokeballs(gameHandler);\r\n      gameHandler.switchPlayer();\r\n      createActivePlayer(gameHandler);\r\n    }\r\n    setTimeout(() => {\r\n      gameHandler.generateAttackButtons();\r\n      gameHandler.generateSwitchButtons();\r\n      gameHandler.generateActionButtons();\r\n    }, 1000);\r\n    animationButtonsExit(buttons);\r\n  });\r\n};\r\n\r\nconst animationButtonsEntry = (buttons: HTMLCollectionOf<HTMLElement>) => {\r\n  for (let i = 0; i < buttons.length; i++) {\r\n    buttons[i].style.animation =\r\n      \"scale-in-hor-center 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both\";\r\n    buttons[i].style.animationDelay = `${i * 0.15}s`;\r\n  }\r\n};\r\n\r\nconst animationButtonsExit = (buttons: HTMLCollectionOf<HTMLElement>) => {\r\n  for (let i = 0; i < buttons.length; i++) {\r\n    buttons[i].style.animation =\r\n      \"scale-out-horizontal 0.5s cubic-bezier(0.550, 0.085, 0.680, 0.530) both\";\r\n    buttons[i].style.animationDelay = `${i * 0.15}s`;\r\n  }\r\n};\r\n\r\nexport const attack = (gameHandler: GameHandler) => {\r\n  console.log(\"bum bum bach!\");\r\n};\r\n\r\nexport const switchPoke = (gameHandler: GameHandler, event: Event) => {\r\n  const nameOfChosenPokemon = (event.currentTarget as HTMLDivElement)\r\n    .textContent;\r\n  gameHandler.switchPokemon(nameOfChosenPokemon!);\r\n};\r\n\r\nexport const eatMango = (gameHandler: GameHandler) => {\r\n  const mangoButton = document.querySelector(\"#mangoButton\")! as HTMLDivElement;\r\n  const mango = document.querySelector(\"#mango\")! as HTMLDivElement;\r\n  gameHandler.currentPlayer.useMango();\r\n  mango.innerHTML = \"0\";\r\n  mangoButton.classList.add(\"disabledButton\");\r\n};\r\n","import { GameHandler } from \"../gameHandlerClass\";\r\nimport { attack, switchPoke, eatMango } from \"./buttonsEventListeners\";\r\n\r\nexport const updateMovesList = (\r\n  gameHandler: GameHandler,\r\n  calledFunction: any,\r\n  event: Event\r\n) => {\r\n  const moveList = document.querySelector(\".gameLogs\")!;\r\n  const newMove = document.createElement(\"p\");\r\n  let newMoveText = document.createTextNode(\"No move found\");\r\n  const pokemonName = gameHandler.currentPlayer.getActivePokemon.name;\r\n  const buttonContent = (event.currentTarget as HTMLDivElement).textContent;\r\n  const playerName = gameHandler.currentPlayer.name;\r\n  console.log();\r\n  switch (calledFunction) {\r\n    case attack:\r\n      newMoveText.nodeValue = `${playerName}: ${pokemonName} used ${buttonContent}!`;\r\n      break;\r\n    case switchPoke:\r\n      newMoveText.nodeValue = `${playerName} changed Pokemon: ${pokemonName} comes into play!`;\r\n      break;\r\n    case eatMango:\r\n      newMoveText.nodeValue = `${playerName} used mango: ${pokemonName} is healed!`;\r\n      break;\r\n    default:\r\n      console.log(\"No move found\");\r\n  }\r\n  console.log(newMove);\r\n  newMove.append(newMoveText);\r\n  moveList.insertBefore(newMove, moveList.firstChild);\r\n};\r\n","import { Player } from \"./playerClass\";\r\nimport {\r\n  actionsButtonEventListener,\r\n  attacksButtonEventListener,\r\n  switchButtonEventListener,\r\n} from \"./fightPage/buttonsEventListeners\";\r\n\r\nexport class GameHandler {\r\n  constructor(\r\n    private readonly _playerOne: Player,\r\n    private readonly _playerTwo: Player\r\n  ) {}\r\n\r\n  private _currentPlayer: Player = this._playerOne;\r\n\r\n  get playerOne() {\r\n    return this._playerOne;\r\n  }\r\n\r\n  get playerTwo() {\r\n    return this._playerTwo;\r\n  }\r\n\r\n  get currentPlayer(): Player {\r\n    return this._currentPlayer;\r\n  }\r\n\r\n  get opponentPlayer(): Player {\r\n    if (this._currentPlayer === this._playerOne) return this._playerTwo;\r\n    return this._playerOne;\r\n  }\r\n\r\n  private didPlayerLoose(player: Player): boolean {\r\n    return player.alivePokemons.length === 0;\r\n  }\r\n\r\n  isGameFinished(): boolean {\r\n    return (\r\n      this.didPlayerLoose(this._playerOne) ||\r\n      this.didPlayerLoose(this._playerTwo)\r\n    );\r\n  }\r\n\r\n  getWinner(): Player | Error {\r\n    if (!this.isGameFinished())\r\n      throw new Error(\"You cannot get the winner. The game is not over.\");\r\n    return this.didPlayerLoose(this._playerOne) === true\r\n      ? this._playerTwo\r\n      : this._playerOne;\r\n  }\r\n\r\n  switchPlayer(): void {\r\n    this._currentPlayer =\r\n      this._currentPlayer === this._playerOne\r\n        ? this._playerTwo\r\n        : this._playerOne;\r\n  }\r\n\r\n  switchPokemon(pokemonName: string) {\r\n    this._currentPlayer.indexOfActivePokemon = this._currentPlayer.pokemons.findIndex(\r\n      (pokemon) => pokemon.name === pokemonName\r\n    );\r\n  }\r\n\r\n  generateActionButtons(): void {\r\n    const player = this.currentPlayer;\r\n    console.log(\"Start - action modal\");\r\n    const actionContainer = document.querySelector(\"#actionModals\")!;\r\n    actionContainer.innerHTML = `\r\n                    <div class=\"button battleButton\" id=\"attackButton\">attack</div>\r\n                    <div class=\"button battleButton\" id=\"switchButton\">switch</div>\r\n                    <div class=\"button battleButton\" id=\"mangoButton\">use mango (<span id=\"mango\">1</span>)</div>`;\r\n    actionsButtonEventListener(this);\r\n  }\r\n\r\n  generateAttackButtons(): void {\r\n    const player = this.currentPlayer;\r\n    console.log(\"Attack choose modal\");\r\n    const actionContainer = document.querySelector(\"#actionModals\")!;\r\n    actionContainer.innerHTML = `\r\n                    <div class=\"button battleButton\" id=\"attackButtonOne\">${player.getActivePokemon.moves[0].moveName}</div>\r\n                    <div class=\"button battleButton\" id=\"attackButtonTwo\">${player.getActivePokemon.moves[1].moveName}</div>\r\n                    <div class=\"button battleButton\" id=\"backButton\">back</div>`;\r\n    attacksButtonEventListener(this);\r\n  }\r\n\r\n  generateSwitchButtons(): void {\r\n    const player = this.currentPlayer;\r\n    console.log(\"Switch choose modal\");\r\n    const actionContainer = document.querySelector(\"#actionModals\")!;\r\n    actionContainer.innerHTML = `\r\n                    <div class=\"button battleButton\" id=\"switchButtonOne\">${player.notActivePokemons[0].name}</div>\r\n                    <div class=\"button battleButton\" id=\"switchButtonTwo\">${player.notActivePokemons[1].name}</div>\r\n                    <div class=\"button battleButton\" id=\"backButton\">back</div>`;\r\n    switchButtonEventListener(this);\r\n  }\r\n}\r\n","import { Player } from \"../playerClass\";\r\nimport { startBattle } from \"../fightPage/startBattle\";\r\n\r\n\r\nexport const startGameIfReady = (playerOne: Player, playerTwo: Player) => {\r\n  if (playerOne.pokemons.length < 3 || playerTwo.pokemons.length < 3) return;\r\n  const app = document.querySelector(\"#app\") as HTMLDivElement;\r\n  startBattle(playerOne, playerTwo, app);\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { GameHandler } from \"../gameHandlerClass\";\r\nimport { createFightPage } from \"./renderFightPage\";\r\n\r\nexport const startBattle = (\r\n  playerOne: Player,\r\n  playerTwo: Player,\r\n  app: HTMLDivElement\r\n) => {\r\n  const game = new GameHandler(playerOne, playerTwo);\r\n  setTimeout(() => createFightPage(app, game), 2000);\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { GameHandler } from \"../gameHandlerClass\";\r\nimport { createActivePokemon } from \"./createActivePokemon\";\r\nimport { createActivePlayer } from \"./createActivePlayer\";\r\nimport { createHPBars } from \"./createHPBars\";\r\nimport { createFightPagePokeballs } from \"./createFightPagePokeballs\";\r\n\r\nconst createPlayerFightNames = (gameHandler: GameHandler) => {\r\n  const playerOneName = document.querySelector(\r\n    \"#fight-page-player1-name\"\r\n  ) as HTMLHeadingElement;\r\n  const playerTwoName = document.querySelector(\r\n    \"#fight-page-player2-name\"\r\n  ) as HTMLHeadingElement;\r\n  playerOneName.textContent = gameHandler.playerOne.name;\r\n  playerTwoName.textContent = gameHandler.playerTwo.name;\r\n};\r\n\r\nexport const createFightPage = (\r\n  appDiv: HTMLDivElement,\r\n  gameHandler: GameHandler\r\n) => {\r\n  const fightPage = document.querySelector(\r\n    \"#fight-page-template\"\r\n  ) as HTMLTemplateElement;\r\n  appDiv.innerHTML = fightPage.innerHTML;\r\n  createPlayerFightNames(gameHandler);\r\n  createActivePlayer(gameHandler);\r\n  createActivePokemon(gameHandler);\r\n  createHPBars(gameHandler.playerOne, gameHandler.playerTwo);\r\n  createFightPagePokeballs(gameHandler);\r\n  // generate choose action buttons\r\n  gameHandler.generateActionButtons();\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { createActivePlayerName } from \"./createActivePlayerName\";\r\nimport { createPlayerNames } from \"./createPlayerNames\";\r\nimport { createPokemons } from \"./createPokemons\";\r\n\r\nexport const createChoosePage = (playerOne: Player, playerTwo: Player) => {\r\n  let activePlayer = playerOne;\r\n  createPlayerNames(playerOne, playerTwo);\r\n  createActivePlayerName(activePlayer);\r\n  createPokemons(playerOne, playerTwo, activePlayer);\r\n};\r\n","import { Player } from \"../playerClass\";\r\n\r\nexport const createPlayerNames = (playerOne: Player, playerTwo: Player) => {\r\n  let playerOneNameAreaText = document.querySelector(\"#choosePagePlayer1Name\")!;\r\n  playerOneNameAreaText.textContent = playerOne.name;\r\n  let playerTwoNameAreaText = document.querySelector(\"#choosePagePlayer2Name\")!;\r\n  playerTwoNameAreaText.textContent = playerTwo.name;\r\n};\r\n","import { Player } from \"../playerClass\";\r\nimport { PokemonFactory } from \"../pokemonFactory\";\r\nimport * as data from \"../../assets/poke_data.json\";\r\nimport { startGameIfReady } from \"./startGameIfReady\";\r\nimport { addChosenPokemon } from \"./addChosenPokemon\";\r\nimport { createPokeballs } from \"./createPokeballs\";\r\nimport { createActivePlayerName } from \"./createActivePlayerName\";\r\n\r\nexport const createPokemons = (\r\n  playerOne: Player,\r\n  playerTwo: Player,\r\n  activePlayer: Player\r\n) => {\r\n  const pokeData = data.pokemons;\r\n  const pokemonFactory = new PokemonFactory(pokeData);\r\n  const pokemonImages = Array.from(\r\n    document.querySelectorAll(\"#pokemonList img\")\r\n  ) as [HTMLImageElement];\r\n\r\n  pokemonImages.forEach((pokemonImage) =>\r\n    pokemonImage.addEventListener(\r\n      \"click\",\r\n      (e) => {\r\n        if (activePlayer.pokemons.length === 3) return;\r\n        addChosenPokemon(e, pokemonFactory, activePlayer);\r\n        createPokeballs(playerOne, activePlayer);\r\n        // change player\r\n        activePlayer = activePlayer === playerOne ? playerTwo : playerOne;\r\n        createActivePlayerName(activePlayer);\r\n        startGameIfReady(playerOne, playerTwo);\r\n      },\r\n      { once: true }\r\n    )\r\n  );\r\n};\r\n","import { Pokemon } from \"../pokemonClass\";\r\nimport { PokemonFactory } from \"../pokemonFactory\";\r\nimport { Player } from \"../playerClass\";\r\n\r\nexport const addChosenPokemon = (\r\n  event: Event,\r\n  factory: PokemonFactory,\r\n  activePlayer: Player\r\n) => {\r\n  const clickedPokemon = event.target as HTMLImageElement;\r\n  const pokemonName = clickedPokemon.id;\r\n  const newPokemonObject: Pokemon = factory.getPokemonByName(pokemonName);\r\n  activePlayer.addPokemon(newPokemonObject);\r\n  clickedPokemon.style.cursor = \"default\";\r\n  clickedPokemon.style.filter = \"grayscale(100%)\";\r\n};\r\n","import { Player } from \"../playerClass\";\r\n\r\nexport const createPokeballs = (playerOne: Player, activePlayer: Player) => {\r\n  const playerPokeballs: HTMLImageElement[] =\r\n    activePlayer === playerOne\r\n      ? Array.from(document.querySelectorAll(\"#choosePagePlayer1 img\"))\r\n      : Array.from(document.querySelectorAll(\"#choosePagePlayer2 img\"));\r\n  const playerLastPokemonName: string = activePlayer.pokemons[\r\n    activePlayer.pokemons.length - 1\r\n  ].name.toLowerCase();\r\n  const numberOfLastPokemon: number = activePlayer.pokemons.length - 1;\r\n  playerPokeballs[numberOfLastPokemon].setAttribute(\r\n    \"src\",\r\n    `./assets/${playerLastPokemonName}.png`\r\n  );\r\n};\r\n","import { Pokemon } from \"./pokemonClass\";\r\n\r\nexport class Player {\r\n  private _name: string;\r\n  private _pokemons: Pokemon[];\r\n  private _indexOfActivePokemon: number;\r\n  private _hasMango: Boolean;\r\n  constructor(name: string, pokemons: Pokemon[]) {\r\n    if (name.length > 8) {\r\n      throw new Error(\"Too long name\");\r\n    }\r\n    if (pokemons.length > 3) {\r\n      throw new Error(\"Wrong number of pokemons\");\r\n    }\r\n    this._name = name;\r\n    this._pokemons = pokemons;\r\n    this._indexOfActivePokemon = 0;\r\n    this._hasMango = true;\r\n  }\r\n\r\n  get name(): string {\r\n    return this._name;\r\n  }\r\n  get pokemons(): Pokemon[] {\r\n    return this._pokemons;\r\n  }\r\n\r\n  set indexOfActivePokemon(numOfActivePokemon: number) {\r\n    this._indexOfActivePokemon = numOfActivePokemon;\r\n  }\r\n  get getActivePokemon(): Pokemon {\r\n    return this._pokemons[this._indexOfActivePokemon];\r\n  }\r\n\r\n  get alivePokemons(): Pokemon[] {\r\n    const alivePokemonsTab: Pokemon[] = this.pokemons.filter((pokemon) =>\r\n      pokemon.isAlive()\r\n    );\r\n    return alivePokemonsTab;\r\n  }\r\n\r\n  useMango(): void | Error {\r\n    if (!this._hasMango)\r\n      throw new Error(\"You cannot use mango. You use all mangos\");\r\n    this._hasMango = false;\r\n    this.getActivePokemon.heal();\r\n  }\r\n\r\n  get hasMango() {\r\n    return this._hasMango;\r\n  }\r\n\r\n  addPokemon(pokemon: Pokemon): void {\r\n    this._pokemons.push(pokemon);\r\n  }\r\n\r\n  get notActivePokemons(): Pokemon[] {\r\n    return this.pokemons.filter(\r\n      (pokemon) => pokemon.name !== this.getActivePokemon.name\r\n    );\r\n  }\r\n}\r\n","export const activateStart = (name1Input: HTMLInputElement, name2Input: HTMLInputElement, startButton: HTMLButtonElement) => {\r\n    if (name1Input.value.length > 0 && name2Input.value.length > 0 && name1Input.value.length <= 8 && name2Input.value.length <= 8) {\r\n        startButton.className = 'button-enabled'\r\n        startButton.disabled = false;\r\n    } else {\r\n        startButton.className = 'button-disabled'\r\n        startButton.disabled = true;\r\n    }\r\n}\r\n\r\n","import { showModal, hideModal } from \"./modalPopUpFunctions\";\r\nimport { createChoosePage } from \"./choosePokemonsPage/choosePokemonsPage\"\r\nimport { Player } from \"./playerClass\";\r\nimport { activateStart } from './activateStart';\r\n\r\nconst renderStartingPage = (appDiv: HTMLDivElement) => {\r\n  const startingPage = document.querySelector(\r\n    \"#starting-page-template\"\r\n  ) as HTMLTemplateElement;\r\n  appDiv.innerHTML = startingPage.innerHTML;\r\n};\r\nconst renderHowToPlayModal = (appDiv: HTMLDivElement) => {\r\n  const infoModal = document.querySelector(\r\n    \"#info-modal-template\"\r\n  ) as HTMLTemplateElement;\r\n  appDiv.innerHTML += infoModal.innerHTML;\r\n};\r\nconst createHowToPlayButton = () => {\r\n  const howToPlayButton = document.querySelector(\r\n    \"#how-to-play-button\"\r\n  ) as HTMLUListElement;\r\n  const infoModal = document.querySelector(\r\n    \"#info-modal-screen\"\r\n  ) as HTMLDivElement;\r\n  howToPlayButton.addEventListener(\"click\", () => {\r\n    showModal(infoModal, \"flex\");\r\n  });\r\n  hideModal(infoModal);\r\n};\r\n\r\nconst activateStartButton = () => {\r\n  const player1NameInput = document.querySelector('#enter-player1-name') as HTMLInputElement;\r\n  const player2NameInput = document.querySelector('#enter-player2-name') as HTMLInputElement;\r\n  const startButton = document.querySelector(\"#start-game-button\") as HTMLButtonElement;\r\n  player1NameInput.addEventListener(\"keyup\", () => {\r\n      activateStart(player1NameInput, player2NameInput, startButton)\r\n  })\r\n  player2NameInput.addEventListener(\"keyup\", () => {\r\n      activateStart(player1NameInput, player2NameInput, startButton)\r\n  });\r\n};\r\n\r\nconst renderChoosePokemonScreen = (appDiv: HTMLDivElement) => {\r\n  const playButton = document.querySelector(\r\n    \"#start-game-button\"\r\n  ) as HTMLButtonElement;\r\n  playButton?.addEventListener(\"click\", () => {\r\n    const player1NameInput = (document.querySelector('#enter-player1-name') as HTMLInputElement).value;\r\n    const player2NameInput = (document.querySelector('#enter-player2-name') as HTMLInputElement).value;\r\n    const choosePokemonScreen = document.querySelector(\r\n      \"#choose-page-template\"\r\n    ) as HTMLTemplateElement;\r\n    appDiv.innerHTML = choosePokemonScreen.innerHTML;\r\n    createChoosePage(new Player(player1NameInput, []), new Player(player2NameInput, []));\r\n  });\r\n}\r\n\r\nconst renderApp = () => {\r\n  const app = document.querySelector(\"#app\") as HTMLDivElement;\r\n  renderStartingPage(app);\r\n  renderHowToPlayModal(app);\r\n  activateStartButton();\r\n  createHowToPlayButton();\r\n  renderChoosePokemonScreen(app);\r\n};\r\n\r\nsetTimeout(renderApp, 2000);\r\n\r\n"],"sourceRoot":""} \ No newline at end of file diff --git a/index.html b/index.html index cf6cc49..e0b516b 100644 --- a/index.html +++ b/index.html @@ -152,7 +152,7 @@

HP:

- + diff --git a/src/choosePokemonsPage/createPokeballs.ts b/src/choosePokemonsPage/createPokeballs.ts index 2640f9d..c6aa7e4 100644 --- a/src/choosePokemonsPage/createPokeballs.ts +++ b/src/choosePokemonsPage/createPokeballs.ts @@ -11,6 +11,6 @@ export const createPokeballs = (playerOne: Player, activePlayer: Player) => { const numberOfLastPokemon: number = activePlayer.pokemons.length - 1; playerPokeballs[numberOfLastPokemon].setAttribute( "src", - `./assets/${playerLastPokemonName}.png` + `./assets/${playerLastPokemonName}.png` // `./${playerLastPokemonName}.eadfd35a.png` For Abra works :D ); };