Using the Object Oriented Programming skills you've learned this week, we want you to implement a Pokemon battle game!
For those of you unfamiliar with Pokemon, you could try to think about it as people (trainers) who have pets (Pokemon), but only have room for 6 pets at a time.
These people are also a bit strange, and they get their pets into fights with other people's pets in the park for no reason at all...
In day 1 of this sprint you are expected to use the pseudo-classical pattern of object creation in order to create your pokemon, trainer and battle objects. Remember to think about which properties and methods should belong to each of these different objects.
In day 2 of this sprint you should re-factor your code to make use of ES6 classes. Any code that uses the pseudo-classical pattern of object creation should be re-factored into classes.
- Each pokemon should have a name, hit points (health), attack damage, the sound that it makes, and one move. (e.g. 'bite')
- Each pokemon should have a type property which deafults to normal. Normal pokemon have no strengths or weaknesses.
- You should be able to create grass pokemon, water pokemon and fire pokemon.
- Fire pokemon are strong against grass, and weak against water. Grass pokemon are strong against water, and weak against fire. Water pokemon are strong against fire and weak against grass.
- Every pokemon should have a talk method available, which returns its sound.
- Every pokemon should have a useYourMoves method available, which returns its favourite move.
- Pokemon trainers will have a name, and a way of storing pokemon.
- Each pokemon trainer will also have a catch method available, so they can store more pokemon.
- Finally, you will need a way to battle the pokemon.
- The battle should take two trainers and the names of the pokemon they wish to battle.
- The battle should have a fight method available. This should take the pokemon whose turn it is, attack the defending pokemon (deducting attacker's attack damage from the defender's hit points), and end their turn.
- The fight method should take each pokemon's strengths and weaknesses into account. If a defender is strong against the attacking type, the attacking type's damage should be multiplied by 0.75. If a defender is weak against the attacking type, the attacking type's damage should be multiplied by 1.25.
- Each attack should be followed by an attack message. The message will vary depending on the defender's weakness/strength.
- If the defending pokemon faints (depletes all hit points), the attacker wins.
Once you have all the necessary parts fully tested, make the game!
Using the inquirer library, build a command line application to play your pokemon battle game. The game should be played using inputs and selections.
- Implement a critical hit, that randomly awards pokemon triple damage.
- A trainer should only be able to hold 6 pokeballs. Limit the number of pokemon that a trainer can store.
- In the original pokemon games, the victor was only declared once all of a trainer's pokeballs contained unconscious pokemon. Improve your battle function so take this into account.
- Trainers should be able to change pokemon mid battle to adjust to changing circumstances. This should end the trainer's turn.
- Pokemon should have a selection of moves, stored in an array. Each move should modify the pokemon's attack damage, and should be available a finite amount of times - determined by its PP (power points). When a move is used, it loses a power point. When there are no more power points for that move, it cannot be used. When none of that pokemon's moves can be used, it 'struggles' by default. This damages the attacker for its base attack value, rather than the defender.