After implementing a producer purchase we need to make sure they do the work!
Each second the producer should give us the amount of gold equal to their baseProduction.
Add a new field productionRate to the config object exported from constants....
The core of our mining game is implemented now.
However, there are a few cosmetic things that we need to work on to provide a pleasant user experience.
For starters, we’ll improve our config by adding two flags isInitCompleted: false and isProducerListUpdated: true...
The prep is done, so let’s start from the beginning.
Once the user has enough gold to purchase the first producer, it makes sense to change the welcome message.
I suggest creating a function checkInitCompleted that should be called from handleKeyPress once the user has enough gold to purchase the first producer....
Next, we’re going to improve the UX by displaying the current list of producers.
We’ll implement the function updateProducerList(term, state) in functions.js
It should print the list of producers, each on the new line starting from line 5....
Wow! The previous stages must have been hard. We still have some work to do, though.
It’d be very useful for the user to see the current production rate of their mining empire....
You might have noticed, that there are occasional issues with displaying the numbers in our game.
Sometimes, there appear long weird tails after the decimal point.
The other times the numbers get so big that it’s hard to make sense of them....
At the moment, we’re updating the UI once a second. It’s ok, but it’d be a lot smoother if it was updating
more often. Let’s say 10 times faster.
You’ll need to change the code in quite a few places,...
Our game should interact with the user in 2 ways. It should know how to accept the keyboard input,
and it should know how to print messages to the console....
So, you’ve already exported the constant term that will allow us to control the terminal.
Let’s make some use of it!
Create the file functions.js and export the function init from it....
Congratulations on passing the stage 3!
You might be wondering why we have 4 files, a third party module and quite a few lines of code to output
a single message on the screen… And the answer is that this structure will allow our code to be flexible,...