Calculator - UI and functional changes

Calculator - UI and functional changes

html-css javascript beginner

In this tutorial, we are going extend the calculator that we built in previous part.

We will mostly do the UI improvement as the functionality of operations is complete.

Source code details included at the bottom of this page.

Demo

See the Pen Calculator in HTML/CSS/JS Part 2 by Cool BRG (@coolbrg) on CodePen.

Update of CSS

Remove unnecessary class

We can remove the CSS class center from table tag by adding margin: auto; to table itself in style.css.

Update following CSS snippets from style.css:

/* Remove following */
table.center {
  margin-left: auto;
  margin-right: auto;
}

/* Update table as below */
table {
  margin: auto;
  border-collapse: collapse;
  border-radius: 5px;
}

And, remove class="center" from table tag in index.html file.

h1 {
  font-family: 'Playfair Display';
  font-size: 130px;
  font-weight: 700;
  color: #555;
  letter-spacing: -57px;
}

Now, if you open index.html file in browser, you should see no difference in alignment of calculator.

Right align result

Right now the text alignment for texbox is left which is default. Let’s update to make it to right side which looks natural.

input[type="text"] {
  ...
  border-radius: 5px;
  text-align: right;
}

Remove blue ring around buttons

Click on any button and you will notice a blue ring around it. See below:

Add following CSS to remove it:

input[type="button"] {
...
}
input[type="button"]:focus {
 outline: 0;
}

Now, if you click on any button, blue ring won’t appear.

Calculator UI changes

In this section, we will try to modify the UI of the calculator.

Udpate width of buttons and textbox

Right now the height and width of calcultor buttons and textbox are quite small. Update them as below:

input[type="button"] {
  ...
  border-radius: 5px;
  width: 60px;
  height: 40px;
}

input[type="text"] {
  ...
  text-align: right;
  height: 40px;
}

Result should look like below:

Button font size, box shadow and margin

Update the button CSS as below:

input[type="button"] {
  ...
  height: 40px;
  font-size: 20px;
  box-shadow: 0 5px rgba(0,0,0,0.2);
  margin: 10px;
}

It will update the font size of button, add the shadow effect which kind of give the 3-D effect to button and add margin to button.

Now, if you see the UI of calculator, it should look like below:

Update border color

Let’s update border color of textbox and button to remove the darkness:

input[type="button"] {
  ...
  margin: 10px;
  border: 1px solid #eee;
}

input[type="text"] {
  ...
  height: 40px;
  border: 1px solid #ccc;
}

Now, UI should look like:

Remove the cell border

Those border like lines around buttons are making whole calculator ugly. Let’s remove it.

Remove the line border: 1px solid #eee; from td, th {. However, if you do that then there is no border and it make the whole calculator kind of free.

Give the border to the table itself which represents the whole calculator:

table {
  margin: auto;
  border-collapse: collapse;
  border-radius: 5px;
  border: 1px solid #eee;
}

One thing which you will notice is the misalignment of textbox with the buttons 1, 4, 7 and ..

Update the textbox CSS as below:

input[type="text"] {
  background-color: white;
  width: 90%;
  border-radius: 5px;
  text-align: right;
  height: 40px;
  border: 1px solid #ccc;
  margin-left: 10px;
}

NOTE: The property width is update to 90% and margin-left is newly added.

The updated UI is:

Highlight first row

Since the first row is special as it contains the textbox and button to clear it, a separation of it from rest of the buttons will improve the UI of calculator.

Add the following CSS at the bottom of style.css file to add a simple bottom border to first row.

table tr:first-child {
  border-bottom: 1px solid #eee;
}

Notice the separation below:

Button hover effect

Lastly, the hover effect to button will boost the whole experience of using the calculator. Add following CSS code below the input[type="button"] to change the background of buttons to darker color than the existing background color.

input[type="button"] {
 ...
}
input[type="button"]:hover {
  background-color: #ccc;
}
It is best practice to group together related CSS code.

Notice below when I hover the button 9, it got highlighted.

Calculator functional changes

Although, we think our calculator is functionally fine, but we have following bugs:

  • Right now, if click on button = then the text box will show undefined
  • Click on operator buttons update the text box. Ideally it should not since the first must be numeric or decimal (.)

Let’s fix above bugs.

Fixing undefined issue on click on equal to

This can be easily fix by checking if the value of textbox is empty or not. If it is empty then just return from the function solve().

Update the solve function as below:

function solve() {
  let x = document.getElementById("result").value;
  if (x == "") {
    return;
  }
  let y = eval(x);
  document.getElementById("result").value = y;
}

Now, if you click on = operator in the calculator, you will find that the bug has been fixed.

Fix operator buttons issue

To fix it, the solution is quite simple.

Inside displayValue() function, we need to store the initial value of text box which is represented by result id.

let initialVal = document.getElementById("result").value;

Then, now when the initialVal is empty and if we click on any of the operators, then we should do nothing and return from the function.

if (initialVal == "") {
  if (["+", "-", "*", "/"].indexOf(val) != -1) {
    return;
  }
}

More better would be to store the list of operators as a constant.

const OPERATORS = ["+", "-", "*", "/"];

...

if (initialVal == "") {
  if (OPERATORS.indexOf(val) != -1) {
    return;
  }
}

Source Code

Find the source code of the tutorial here.

Help me to improve Dhanu Sir.