Productivity Tracker is a magic mirror, but instead of displaying the time, weather and a motivating quote, it displays 4 things;
And if the percentage of the time you've spent on productive material is over 50% the LEDs will display a bright green color. If it is under 50% it will display a red color, signaling you to be more productive! You can also set a goal yourself.
Outline
In the first step, I will explain the idea behind productivity-tracker. Next, I'll give you two different tools&parts list, so you can build the full project or a basic version(Doesn't include the LEDs) that does not require soldering skills. Later I will show you how I prototyped my version of the project, so you have an idea on how to model your own prototype. Also, I will get into detail at the code section so you can customize the code for your own needs. At the end, I will give you a Trouble-shooting guide based on the problems I encountered during this build. And expand the list with your questions.
The purpose of this instructable is not just to give you a cookbook. I'll show you the way I built this project and provide you with open-ended questions, so you can add your own ideas, and take this project even further. I strongly encourage you to share your build when it's done! Let's get started.
I have been intending to write this Instructable for months. But an old friend of mine who goes by the name of "Procrastination" didn't let me. Procrastination is the act of delaying or postponing a task or set of tasks, and instead of doing those tasks filling the time with watching videos from the dark depths of YouTube.
One day while reading an article on procrastination I came across multiple apps/programs that would help me with my problem, Trello as a task management app and RescueTime as a time management app. Both worked perfectly for my needs, for a time at least. After a while, I stopped checking the apps altogether and ignored the notifications. That is when I came up with this project. I would display the data from apps on a mirror hanged up on my wall. This way there was no escape from my responsibilities.
The first draft I draw for my project was fairly simple. I would use the RescueTime API to display my Productive/Distractive work percentage. And use the Trello API to display my to-do list for the day. But after a while, I added more features that I will get in detail in the next steps.
Note: This is a list of tools I used during my build, they do not have to be the same for your build!
For the Base:
For the Led Lightning:
Tools:
This step will be in 3 parts, you don"t need all the parts listed in the previous step. A Raspberry Pi and the monitor you"ll use for this project should be enough for the prototyping stage.
If you did not set your Raspberry Pi yet go ahead and do it here. For this build, you"ll need to install Apache for the web server and the PHP-LED-controller.
To install Apache follow this official guide.
To install the PHP-LED-controller follow this guide by Christian Nikkanen
Now download the index.php file from the project repository to your Raspberry Pi and put it on this path:
/var/www/html/
If you are unfamiliar with moving files around in Linux Terminal, you can look at this guide to get you started.
Note:This part requires a little bit of HTML/CSS knowledge if you are using a different monitor.
The customization will be done on the index.php file which is the hearth of this build. Now go ahead and connect your monitor to your Raspberry Pi if you didn't already.
Now if you try to open the index.php file it won't work because you first have to fill the API keys in the code, for that go to the RescueTime website and open an account. Next, go to the developer section and create an API key by pressing Activate This Key. Write Your API key to somewhere.
Do the same for your Trello API key, Open an account and go to the developer portal to generate an API key.
Next, open the index.php file that you put into /var/www/html/ in your favorite text editor, and replace [API_KEY] with your own API key that you got from RescueTime and Trello accordingly. The[list_number] is the list number that you use for your to-do list Trello. To get that number first create a fresh list on Trello and call it "To-Do", this will be the list that you'll use for your to-do list and it will appear on the mirror.
Next, Take the URL on your address bar that looks like:
https://trello.com/b/3hS6yyLo/board-name
and add .json to it like this:
https://trello.com/b/3hS6yyLo/board-name.json
and press enter, next you'll see a code mess on the screen. Try to find your list name ''To-Do" on that mess. It should look something like this: {"name":"To Do","id":"5981c123cd1b23f13907cd18"}, That Id is your list Id. put that number to [list_number] on the index.php file.
Now open your browser and type localhost to the address bar and press enter. You should see your data displayed on the graphs.
Note:The placements of the graphs can be different because of the resolution of the monitor that you are using. You can edit the width, height and location of the elements in the CSS part of the code.
Now all left to do is to design a box around the monitor and connect the LEDs.
Note: If you are not interested in the API's in detail you can skip to the next step. In the API's part I will get in detail how the whole program works and gets data from APIs.
The hearth of this project is the Two APIs;
Although the documentation has detailed information available, I'm going to explain which data from the API this project is using.
On the time management part, the RescueTime API call that gets the time info for the current day is,
"https://www.rescuetime.com/anapi/data?key=[API_KEY]&perspective=rank&interval=hour&restrict_begin=".date('Y-m-d')."&restrict_end=".date('Y-m-d')."&format=json"
where,
date('Y-m-d')is the current date
perspective=rankis the data sorting type in this case "rank" which stands for most time spent
This call will give a file in JSON format that looks like this:(look at data.json at the end of this step)
The data we use from this file is the "Time Spent (seconds)" and the "Productivity" which has values between -2 and 2, -2 being distractive and 2 being productive. With this data, we can generate a value over 100 for the productivity score.
Another API call to RescueTime,
"https://www.rescuetime.com/anapi/daily_summary_feed?key=[API_KEY]"
Which gives you a weekly summary of your data, which looks like this:(look at summary.json at the end of this step.) I used this data to generate the weekly summary graph that gives you an overview of the week.
The Trello API call,
"https://api.trello.com/1/lists/[list_number]/cards?fields=name&key=[API_KEY]&token=[Token]"
This will give you the cards on your Trello list like this:
[{"id":"5a4160103bfcd14994852f59","name":"ceylan cinemagraph"},{"id":"59e8241f6aa8662a51eb7de6","name":"Learn GitHuB"},{"id":"5981c19577c732f826ad8025","name":"Publish Instructible"},{"id":"5a341dba7f17d235d7c5bbd1","name":"SPACE PROGRAM"}]
again you can pull the text on those cards and put that on somewhere else.
Now you have your data displayed on the monitor, it's time to design the mirror around your monitor. You have many designs to choose from, I used a light colored wood in my project since it was more compatible with my room.
There are really good magic mirror Instructables out there, check them out if you want to choose a different frame;
https://www.instructables.com/id/Smart-Mirror-by-R... by batynator
https://www.instructables.com/id/Raspberry-Pi-Smar... by HackerHouse
https://www.instructables.com/id/Magic-Mirror/ by khinds10
for my frame cut the wood by the dimensions:
Front:
Back
Some Notes:
Note: If you are building the basic setup and don't want the LEDs, you can skip this step.
The schematics and the LED control setup are from 2 separate tutorials that I used in conjunction. Go check them out!
How to control a RGB LED-Strip with a Raspberry Pi by David Ordnung
Raspberry Pi PHP LED controller by Christian Nikkanen
Important Note:
I've used the following pins:
If you want to use different pins, you have to change the pin numbers in the beginning of index.php
At this point, everything should be working fine, but you still have to use a mouse and keyboard to start up your browser and type localhost on the address bar.
To open your browser and localhost on boot you have to do the following;
sudo nano /home/pi/.config/lxsession/LXDE-pi/autostart
2. Add the following line:
chromium-browser --kiosk --incognito "http://localhost/index.php"
Now you can disconnect your keyboard and mouse, your browser should start at boot and open up the index.php file.
#Seconds to refresh the webpage<br>$sec = "360";
if ($oran<50) { $led->setHex("#FF0000"); }else { $led->setHex("#00FF00"); }
you can use this HEX color calculator.
I used the chart.js javascript library for the graphs. You can follow their documentation for more:
This project is open for a lot of improvement, I did not have an additional budget for this build so I had to build with what I already had. Here are some things that I think should be improved or added:
Well, I hope you enjoyed this project and learned a few things while building it. If you catch any mistake in the text or error in the code please let me know.
All questions are welcome!
You can also contact me at: [email protected]