Home Cooling Fan Made Smart with JavaScript [Tutorial]by@codebeast
1,635 reads
1,635 reads

Home Cooling Fan Made Smart with JavaScript [Tutorial]

by Christian NwambaNovember 2nd, 2019
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

With a Tessel 2 and a relay, we cloud turn this so-called damaged fan into one of the smartest device in our friend’s home. The best way to follow this article is to get the same devices we used but of course you might not have that luxury. The only thing you should care about are the wires we pulled out of the control chip. The components that make up the mechanics of the fan are: A big fan motor, a capacitor, a small fan motor and a power source.

Companies Mentioned

Mention Thumbnail
Mention Thumbnail

Coin Mentioned

Mention Thumbnail
featured image - Home Cooling Fan Made Smart with JavaScript [Tutorial]
Christian Nwamba HackerNoon profile picture

(This article is co-authored by Chinedu Imoh)

Our friend had a damaged fan — the fan’s control board got fried. We were tired of seeing it lie around the house when we visit her on weekends but recycling electronics in Nigeria is not a thing.

We thought, instead of harming the world by throwing the fan away, we could just pull out the damaged board, join the wires under the hood manually and still have the fan work.

(Alt: Type of fan used for article demo)

With a flat screw driver, as seen in the picture on the right, we pulled out the control panel of the board and cut out the wire from the board.

(Alt: Pulled out control chip (the actual damaged fan is a black one — we got a white one that’s good)

At this point joining a couple of wires would get the fan back to live but it’s the era of IoT and we thought to ourselves — “this is a free fan we could play with, what can we do?”

Well it didn’t take us too long to REALIZE that with a Tessel 2 and a relay, we cloud turn this so-called damaged fan into one of the smartest device in our friend’s home.

This article outlines our journey to how we made this fan smart. At the end, you will learn:

  1. What requirements we used to make this fan smart
  2. How we used a relay to interface this fan with a Tessel IoT board
  3. How we controlled this fan with a computer (can be a phone) through a Tessel board

The best way to follow this article is to get the same devices we used but of course you might not have that luxury. This is why we are structuring this post in a way that you can apply what ever you learn in your IoT journey — regardless of whether:

  1. This is your first look at IoT
  2. You have been doing IoT stuff but want to learn how to control home appliances with IoT


This upcoming list does not have to be followed religiously and you can replace each part with what ever works best for you:

  1. A room fan — we are using Honeywell QuietSet Fan
  2. Tessel 2 IoT Board
  3. Saint Smart Relay
  4. Jumper cables
  5. Basic knowledge of JavaScript/Node
You can buy a Tessel kit which comes with Tessel 2, cables, few sensors, etc. The relay and fan does not come with the kit but you can get those from the links.

Circuit Diagram

We are totally aware that this article targets both developers as well as electrical engineers. With this in mind, we chose to not draw a professional circuit diagram but a simpler flow diagram of what the connections look like.

The secondary reason for not making a professional circuit diagram is because we both have computer programming background and suck terribly at such.

(Alt: Circuit diagram)

The only thing you should care about are the wires we pulled out of the control chip. That said, feel free to skip the next section if you don’t want to understand where those wires poking out of the fan came from.

How the fan works

The components that make up the mechanics of the fan are:

  1. A big fan motor
  2. A capacitor 
  3. A small fan motor(for swing/rotation)
  4. Power source

The big fan motor has five multicoloured wire’s — two (green) are connected to the capacitor, the next two (yellow and red) are connected to the chip (which we pulled out), and the last one(white) is connected to the smaller motor which in turn also goes to the board.

Capacitors are devices which store electrical charge, a motor capacitor, such as a dual run capacitor is an electrical capacitor that alters the current to one or more windings of a single phase AC induction motor to create a rotating magnetic field. In this case both(green) wires of the capacitor are connected to the big fan motor to run both motors.

The small fan motor is used to rotate the body of the fan so as to distribute air to the room. Both blue and black of the small fan motor wires are taken the board, but the blue is first connected to the big fan before getting connected to the board.

The 2 power source (140V wire’s) both go straight to the board.

In summary with regard to the wires we pulled out, the white and the the blue are used by the relay to toggle the fan while the black and yellow are used to toggle the swing. The remaining two wires (red and brown) can be used to toggle both power and swing at once.

Setting up Tessel 2

Install the Tessel 2 node module using the following command:

npm install -g t2-cli

Plug in the Tessel to your computer using the provided USB cable. You can refer to the following image to see how this connection should be made:

(Alt: Connecting Tessel to a computer)

It takes 30 seconds to finish booting — at this stage a light will blink until booting is completed. After the Tessel is done booting, run the following command to find it:

t2 list

You should see a message like the one below:

INFO Searching for nearby Tessels...
  USB Tessel-AF768F095

 means it’s connected via USB. You can connect via wifi which we will see soon.

is the name of the Tessel. You can choose to rename it with:

t2 rename <name>


 is the new name. Running
t2 list 
again will list the Tessel but with its new name:

INFO Searching for nearby Tessels...
  USB HomeFan

Connect Tessel to Wifi

Connecting to wifi is pretty straightforward — with the Tessel still connected to your computer, run the following command:

t2 wifi -n <network-name> -p <password>
  • <network-name>
     is the wifi SSID or network name
  • <password>
     is the wifi password

We have tried connecting to a hotel wifi and it didn’t work. If that’s the kind of network you are on, I am not sure you will have the best luck connecting.

You can choose to push your JS code to Tessel using wifi instead of USB. To set that up, run the following command:

t2 provision

With that in place, you can run 

t2 list
 again to confirm wifi is authorized. You see the following:

INFO Searching for nearby Tessels...
        HomeFan        LAN
        HomeFan        USB

Board connections

If you can join legos, you can totally do this kind of connections.

Before you move on, I would like to warn you that the relay is a high voltage device. Once connected to the fan and the fan is powered, there are chances of being electrocuted if you skin gets in contact.

Tessel 2 ←→ Relay

Before we move on with any connection, this is what a Tessel 2 board and our Relay looks like:

(Alt: Tessel 2 and Saint Smart Relay)

A note on both…

The Tessel is the CPU of our setup. This is what we will ship JavaScript to setup a network access point, control the I/O devices (eg the relay) etc. Basically, this is the board that replaces the chip we pulled out earlier.

The black rectangle plunging out of the board (picture coming soon below) is where you connect your input and output devices. This is where we will connect the relay to. You can also connect sensors, displays, and other accessories using this port.

The saint smart 4 pin relay module is a separate hardware device that takes instruction from a 5v chip, for example Tessel 2, and uses the instruction to control high voltage devices of up to 240v (eg. fan). With out the relay the micro-controller can only control devices of 5v and below.

We need to get the connection right for this relay — here is a connection diagram:

(Alt: Tessel 2 and Relay port mapping)

With the jumper cables, connect the 0 port of the Tessel to IN1 port of the relay. Do that for the rest of the ports as mapped below:

  • 0 ←→ IN1
  • 1 ←→ IN2
  • 2 ←→ IN3
  • 3 ←→ IN4

The following image shows the required wiring between the Tessel and the relay:

(Alt: Showing I/O connection as well as GND and 5v connection for relay)

The first thing that will throw you off is that we have a blue and brown cable running out of the GND and VOC ports, respectively. These GND port stands for ground and that is how you ground the relay. This means you need to connect it to the GND of the Tessel 2. The VOC is 5v power source for the relay and it has to go to the 5v port of the Tessel as well.

On the Tessel 2, here is how the blue and brown cables run into the Tessel’s GND and 5v ports:

(Alt: GND and 5v connection)

Relay ←→ Fan

We have seen how to connect the IoT board to the relay, now we need to connect the relay to the fan:

(Alt: Relay to fan connection)

Programming the Tessel 2

We want to be able to control the fan from our phones and laptops. One way we can do this is to have a node server run on the Tessel. This is totally possible. You can have a usual node server run on Tessel and access the Tessel from an IP address.

With all your connections still in place, make sure the Tessel is connected to your computer and run `t2 list` to make sure it’s all setup.

To create a code project, cd into the folder you want to code to live and run the following:

t2 init && mkdir public

This will setup a Tessel project with a

file. It will also create a public folder for the browser client app.

Install the following node packages:

npm install --save express body-parser tessel tessel-gpio-relay

A node server

Create a 

 file in the root of your Tessel project with the following content:

// Dependencies
const path = require('path');
const relaylib = require('tessel-gpio-relay'); 
const tessel = require('tessel')
const express = require('express');
const bodyParser = require('body-parser');
const app = express();
const http = require('http').Server(app);
const io = require('')(http);

const port = process.env.PORT || 80;

// Setup relay ports
const relay = relaylib.use(tessel.port['B'], [1,2]); 

// Express middlewares
app.use(bodyParser.urlencoded({ extended: true }));

// Server public folder as static content folder
app.use(express.static(path.join(__dirname, 'public')));

// Index page route
app.get('/', function(req, res) {
  res.sendFile(path.join(__dirname, '/public/index.html'));

//// websocket code coming soon...

// Listen to port
http.listen(port, function() {
    'Your server is up and running on Port ' + port + '. Good job!',

This is an express middleware and what is going on is beyond the scope of this article. In summary, we have setup an express HTTP app and a websocket using
. The
route responds to the index requests sent to our server.

Note how we are using the relay library and the Tessel library to setup a port on the Tessel and map it to the relay IN1 and IN2.

As for the content shown in the 

, create an
file in the
folder with the following:

<!DOCTYPE html>
<html lang="en">
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Set a Color</title>
  <link rel="stylesheet" href="style.css">
  <h1 id="state">Set Mode</h1>
  <form method="POST" action="">
    <input type="button" onClick="toggleFan()" value="FAN"></input>
    <input type="button" onClick="toggleSwing()" value="SWING"></input>
  <script src=''></script>
  <script src="script.js"></script>
    const socket = io();
    const modePicker = document.getElementById('statePicker');
    function toggleFan(){
      socket.emit('fanChange', 'CHANGE');
    function toggleSwing(){
      socket.emit('swingChange', 'CHANGE');

Two controls — 

represented and buttons. The intention is that when
is clicked, the fan should go on but when
is clicked, the fan would start swinging to spread across the room.

The buttons have event listeners on them calling 


In the script file, we are using 

socket .io 
to emit events on the websockes back to the server. Now we need to go back to
to listen to the events.

Kicking the relay

Once the events are emitted from the web app, we need to listen to it and toggle the relay:

io.on('connection', socket => {
  socket.on('fanChange', data => {  
    relay.toggle(1, function toggleOneResult(err) {
      if (err) console.log("Err toggling 1", err);
  socket.on('swingChange', data => {
    relay.toggle(2, function toggleOneResult(err) {
      if (err) console.log("Err toggling 1", err);

When the event is received, we can either toggle the

of the relay to start or turn off the fan, we can also make the fan swing or not with

Starting the Tessel

Before we run the Tessel, we need to find the IP address to reach it with. To get the IP, run the following command:

t2 wifi

This will take print the network information of your Tessel including the IP address:

INFO Looking for your Tessel...
INFO Connected to HomeFan.
INFO IP Address:
INFO Signal Strength: (61/70)
INFO Bitrate: 58 Mbps

Copy the IP address, then run the following:

t2 run server.js

Make sure your computer or phone is on the same wifi network with the Tessel 2 then visit the IP address and you should see the app. Click the fan button to turn on the

and you can also swing using the

(Alt: App UI)

What’s Next?

If you followed to this point, then you have done all the hard work it takes to make a smart device. The next thing you would want to try is to control your device from a different network. Currently we rely on the computer/phone to be on the same wifi as the Tessel — most times, this is totally fine. 

Sometimes though, you want to be able to control your device when you are not at home. To do this you need to connect your IoT to a hub. You can apply the technique in this article to connect your device to IoT hub and control it from a cloud.

You can also use temperature sensors to start or stop this fan based on the temperature of the room.