Header from Freepik.com with background vector created by Brgfx

What Is This and Why the Excellent Clashing Color Scheme?

iFeel originated as the final project for the freshman honors class CS 196 at the University of Illinois at Urbana-Champaign. I have since expanded it from a chat app with a Bot Button to better achieve my initial vision for it. This included adding:

  • Multiple groups with everything that entails (creation, modification, and selection being the big visible pieces from the frontend).
  • A navbar replete with buttons decked in homegrown icons to give the user access to this functionality and more.
  • A slide-in scollable menu to select messages from.
  • Upgraded bot functionality making use of sentiment analysis to select a somewhat appropriate response to the last post by another user.

Specifically, this is a cross-platform group messaging app that allows people to interact with others using a limited subset of emotions and feign caring about others’ emotions with a bot. This is accomplished by limiting the user to posting only from a dropdown of preselected phrases, emojis and emotionally empathetic and supportive responses. This list, compiled by a CS major (who could possibly be more qualified), includes in its twenty-something posts the full possible range of human emotions from “I feel sad” to “I feel very happy”. Should actually selecting a message to show that you care about someone else’s feelings be too much for you (I mean, you are on the platform to receive validation, not to give it after-all) fear not, for there is the Bot Button which will automagically select an emotionally appropriate response (to some approximation) through the marvel that is sentiment analysis.

The inspiration for the name comes from an imaginary app in the novel The Nix by Nathan Hill.

As for the color scheme, the answer boils down to a lack of artistic talent rationalized post-hoc as school pride—ILL-INI!

Screenshots!

iFeel splash screen iFeel login screen iFeel group selection screen iFeel chat screen iFeel input dialog iFeel account creation screen iFeel chat group creation screen
Screenshots of app. From left to right: splash, login, group selection, chat, input dialog, account creation with input validation error, and chat creation screens.

Technical Information!

iFeel is built with:

  • React-Native: app frontend (actual code written in Javascript, JSX, and CSS for styling).
  • GiftedChat: React Native library used to render chat UI (namely message bubbles).
  • Firebase: backend — authentication and storing message, group, and user data in its NoSQL RealTime Database.
  • Sentiment: a Node library that uses some basic natural language processing to assign an emotional valence ranging between -5 and 5 to text and emojis.
  • Node & Expo: Used to run app locally on iOS and/or Android.

Awards

None, I just had a lot of fun and learned quite a bit working on this both during the semester and after.

But wait, there’s more!

I have been keeping this project under somewhat active development and any ideas, recommendations, and even code requests are welcome. Currently, I am eyeing possibly adding notifications and adding local caching of some messages.

The code is open source, and you can check it out on Github here.

Alternatively, if you are just interested in playing around with the app, you can just download the Expo Client app, search for iFeel from it, and seamlessly run it on your phone (it will run off of my free tier Firebase project though, so please do not do anything too excessive with it).