šŸ‘‰ Emoji translations with the šŸ“ž Twilio API for šŸ’¬ WhatsApp and Node.js

August 01, 2018
Written by
Phil Nash
Twilion

twilio-loves-whatsapp

I 💖 emojis, so when I heard about the new Twilio API for WhatsApp I wanted to build something emojiriffic. Inspired by Monica Dinculescuā€™sĀ to_emoji Twitter botĀ and emoji translatorĀ I decided to build a WhatsApp text-to-emoji translator. You can try it out now by sending your message to our WhatsApp number +441745472072.

An example of sending a message to the app we're going to build. The WhatsApp number responds with the message translated to emoji.

Hereā€™s how you too can build this app.

🛠 Tools

I decided to build this project using Node.js, following in the footsteps of Monicaā€™s projects. WhatsApp messages via Twilio result in webhooks, much the same as receiving an SMS message to a Twilio number, so if youā€™ve built a Twilio SMS application before this will be familiar. For ease of deploying this, Iā€™m going to build this as a Twilio Function.

If you want to follow along with building the emoji translator youā€™ll need:

And thatā€™s all. Letā€™s get building!

🏗 Building the app

First up, letā€™s take a look at the what powers Monicaā€™s apps.

Powering both of them is the moji-translate module, which in turn uses the emojilibĀ keyword library by Mu-An Chiou. To use moji-translate in a Twilio Function we need to install it.

In the Twilio console, head into the RuntimeĀ section to configure your Functions. In the dependencies section add version 1.0.8 of moji-translate. Save the config and weā€™re ready to build the function.

Add moji-translate and the version 1.0.8 to the dependencies section, then save.

Add a new Function from the management pageĀ and choose the ā€œHello SMSā€ template, as responding to an incoming WhatsApp message uses the same TwiMLĀ as responding to an incoming SMS message. Give your Function a name and a path.

Give your function a name and a path.

The code should look like this so far:

exports.handler = function(context, event, callback) {
Ā  let twiml = new Twilio.twiml.MessagingResponse();
Ā  twiml.message("Hello World");
Ā  callback(null, twiml);
};

To build our emoji translator we will first need to grab the body of the incoming message from the event object. Ā We can then pass it through the moji-translate module and return it in the TwiML in the place of ā€œHello Worldā€ in the above example.

exports.handler = function(context, event, callback) {
Ā  const { translate } = require('moji-translate');
Ā  const incomingBody = event.Body;
Ā  const translatedBody = translate(incomingBody);

Ā  const response = new Twilio.twiml.MessagingResponse();
Ā  response.message(translatedBody);
Ā 
Ā  callback(null, response);
};

Save the Function and it will automatically deploy. Copy the URL as we will need it to configure the WhatsApp channel.

Open the WhatsApp sandbox, find the field for when a message comes in and paste in the Function URL. Save the channel and prepare to test!

📱 Testing the app

Open up WhatsApp on your phone, send a message to the sandbox number and youā€™ll receive a response with your message translated to emoji.

Or in emoji:

👐 🆙 WhatsApp 🔛 your 🤳, send a 💬 to the sandbox 2āƒ£ and youā€™ll receive a response with your 💬 translated to emoji.

A screen shot of the original and translated message.

If you get a message back saying your number is not associated with the sandbox channel, make sure you follow the instructions to connect your number to the sandbox.

If you want to try the app out without connecting to the sandbox, send your message to our WhatsApp number +441745472072. You can start a conversation by scanning this QR code with your phone too.

Scan this QR code and start translating your text to emoji over WhatsApp.

👞 Next steps

Emoji translation via WhatsApp isĀ possible with only a few lines of code when you have the right tools to hand. In this post weā€™ve seen how you can build, deploy and scale an application using Node.js and Twilio Functions, with all the emoji power supplied by moji-translate. This is just the start though, you can build on this to create more interactive applications with Twilio, WhatsApp, and the other channelsĀ available through the Twilio messaging API.

Now we have the WhatsApp sandbox to play with, what other apps are you looking forward to creating? Get in touch in the 💬 comments below, 📧 email me at philnash@twilio.com or send me your favourite emoji on 🐦 Twitter at @philnash.