This project allows you to set up an ePaper display on your desktop, which shows the next couple of meetings from your calendar. It uses hardware you can simply purchase on Amazon - an ePaper display and a Raspberry Pi Zero - and optionally a 3D printed case. Software wise, it uses ePaper.js as the framework for printing on the ePaper display, Create React App and express.js.
- Waveshare 7.5" ePaper display - Amazon
- Raspberry Pi Zero WH - Amazon
- Raspberry Pi Power Supply - Amazon
- 16GB MicroSD card - Amazon
- 7.5" enclosure (optional) - Amazon - in case you can't 3D print a proper enclosure
If you have access to a 3D printer, I used this awesome design as an enclosure.
In order to be able to login to your Google calendar, you will need to set up an app on Google Cloud Console.
Steps:
- Set up a new project under Google Cloud Console.
- Enable the Google Calendar API for your newly created project.
- Create new credentials for your project:
- Goto the credentials page and click on the "Create credentials" button
- Choose the OAuth Client ID option
- Choose Web application for application type
- Add
http://localhost:3000
under "Authorized JavaScript origins" andhttp://localhost:3000/api/auth/login/callback
under "Authorized redirect URIs", click save - Copy the created Client ID and Client Secret, you will need them later
- Update the OAuth Consent screen:
- Go to the OAuth consent screen setup page
- Give your app a name and provide your email (not that important since you will be the only one using this app), click Save and Continue
- Click the "Add or remove scopes" button and select the
calendar.events.readonly
scope, click Save and Continue - Save your app
- use Raspberry Pi Imager
- finish installation on the desktop and connect to wifi
- optionally enable SSH
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash
Install node lts See here: https://dev.to/patrickweaver/installing-node-12-and-higher-on-a-raspberry-pi-zero-with-nvm-4dnj
NVM_NODEJS_ORG_MIRROR=https://unofficial-builds.nodejs.org/download/release nvm install 14
check node version
node -v
v14.18.1
sudo raspi-config
# Choose Interfacing Options -> SPI -> Yes to enable SPI interface
sudo reboot
sudo apt-get update
# Install wiringpi
sudo apt-get install -y wiringpi
# For Pi 4, you need to update wiringpi (skip otherwise):
cd /tmp
wget https://project-downloads.drogon.net/wiringpi-latest.deb
sudo dpkg -i wiringpi-latest.deb
#You will get 2.52 information if you've installed it correctly
gpio -v
# Remaining dependencies
sudo apt-get install -y build-essential chromium-browser
npm i -g agenda-paper
Create a config directory called .agenda-paper
under your home folder
mkdir ~/.agenda-home
Create an .env
file under the config directory and add the GCP app credentials
echo "GOOGLE_CLIENT_ID=<enter your app's client ID>" >> ~/.agenda-paper/.env
echo "GOOGLE_CLIENT_SECRET=<enter your app's client secret>" >> ~/.agenda-paper/.env
# this is optional, in case you want to use another display supported by ePaper.js
echo "EPAPER_DEVICE_TYPE=<device_type_id>" >> ~/.agenda-paper/.env
On your raspberry pi terminal (or SSH), run agenda-paper
agenda-paper
You should be seeing a prompt on your ePaper display to set up your account. Follow the instructions to set everything up. Eventually, you should be seeing your agenda on the display.
First, let's install pm2
globally.
npm i -g pm2
Now, let's run setup pm2 on system startup:
pm2 startup
Run the command shown in the output - should be something along these lines:
sudo env PATH=$PATH:/home/pi/.nvm/versions/node/<version>/bin /home/pi/.nvm/versions/node/<version>/lib/node_modules/pm2/bin/pm2 startup systemd -u pi --hp /home/pi
Now, let's run agenda-paper
using pm2
pm2 start agenda-paper
Finally, let's persist agenda-paper
on pm2
app list
pm2 save
If everything goes well, agenda-paper should be started automatically on system startup
To check the app logs under pm2
, use the following command:
pm2 logs