Motivation
Our motivation for creating this app is to develop a space where a variety of students, which includes foreign, transfer, and incoming freshman students, can connect with others, tackling the issue of an overwhelming lifestyle transition into university. Our app seeks to make connections less intimidating by providing organization as well as a separation between personal socialization and school persona. It serves to encourage students to connect with others so they don’t have to put so much effort into searching for similar resources. As frightful as it is to step out of one’s comfort zone and introduce yourself to others, our app will prove to be a comfortable environment that will encourage socialization using an anonymity feature. Centered around group chats, a casual tone will create a sense of friendliness and keep our users comfortable.
Goals
In order to connect different university students with each other, our app provides access to different University-related groups, activities, and individuals so that students have the ability to make this college lifestyle transition with ease.
Ideally, our app will have an active user base with people in the University community being actively involved in the creation, management, and interaction of their individual groups and activities. The amount of users active on the app will hopefully reflect the increase of comfort and the decrease in intimidation of connecting within the student demographic.
We also would like to implement a feature that allows the students within a certain group or community to bond with other members of a shared grouping. On top of this, we would like to maintain user retention on the app by motivating them to keep logging on almost daily. Nothing builds comradery faster than having a shared goal. Each group chat will be able to take care and raise a plant into a tree by watering it every day.
In future implementations of our application, we aim to obtain certain members of different groups that serve as potential “ambassadors” or “leaders” of their groups in order to help manage and encourage members of their communities to help. Having a leadership role also can help to moderate happenings within the group.
Usage
Below, you can find the different pages that make up our current application implementation of ConnectUni.
Here is the working logo:

- Splash Screen: Upon clicking on the app, the user is presented with a splash screen of our logo, which hopes to combine the idea of connecting university students. Connect (USB Cable) and Uni (The graduation cap).

- Sign In Page: When the user opens the app, the login page will be the first page seen. On this page, users are given the option to enter in their emails and passwords if they already have an account. If they enter an incorrect email, password, or both an error will occur. The user is also given the option to click the register button to go to the Register page, or hit the “Forgotten password?” text to send an email to their account to reset their password.


- Register Page: If the user has not yet created an account, they will be able to go to the register page and create an account by providing an email and a password. There is a second section for a user to confirm their password to ensure that they are typing it correctly the first time. Upon hitting register, the user will be prompted to validate their email and then will be sent to the “Create profile page”.

- Create Profile Page: After Signing up, the user is prompted to set up their profile with a Display Name, a profile picture field, a major field, their projected graduation, and an optional status that describes how they are feeling. Currently the profile picture field is only linked to images that are found in our assets folder, but we are aiming to change this in the future.

- Home Page: Upon logging in, the user is shown the Home page displaying a list of groups that the user is currently a part of. There is an add button at the bottom prompting users to add to their current list of groups by creating a group. If the user’s group list is empty, the user is prompted to join or add to a group to start filling out the page. The page also is the first introduction to the application AppBar as well as the Navbar at the bottom, which shows the user the groups, messages, event calendar, and their own profile.


- Group Chat Page: A user can select a chat from their joined groups which they can then send and recieve messages from other members of that group.


- Group Info Page: After a user selects a group from the login page, they will be able to see that specific groups information. This will include the members of that group as well as a brief description of what the user can expect from that grouping. There will also be a field that shows the group’s interests that the user can search upon. At the bottom there will be either a group join or a group leave button depending on whether or not the user is in the group. If the user is a member of a group, they are also given access to an edit button, which is described below.


- Edit Group Page: If a user is a member of a group, they have the option to edit group information using a form. The form is pre-filled with the change-able aspects of the group. When submitted, the group information is updated in the database. There is also a reset buttton that resets all form fields to empty.

- Add Group Page: There is also an add group page in which a user is able to create a group in the event that there isn’t one made for their intended use already. The fields for this are empty with some placeholder information to guide the user to filling out the correct information. This can be accessed from the search groups page (see below) and also allows the user to refresh the page.

- Search Groups Page: A user can search for groups to join and can filter certain Clubs/Interests/Majors/etc. in which groups are categorized in. At the bottom of this page is a section in which the user is able to create a group (see the above section).

- Search People Page: A user can search for other individuals to connect with and can filter by Clubs/Interests/Majors/etc. in which individuals are apart of.

Here is an example of our filter in use:

Clicking on these user profiles will bring you to a profile that allows you to view their information, send them a message, friend them, or view/join their groups.

- Search Events Page: A user can search for events to attend and can filter by Clubs/Interests/Majors/etc.

- Create Event Page: Through the search events page, you can navigate to add an event. Since events are linked to groups, the group section of this document is specifically linked to the user’s list of groups.

- Event Info Page: The user is able to view the event information and are given a prompt to join. If they are not in the group associated with the event, they are instead prompted to join the group.

- Edit Event Page: When the user is in the group associated with the event, they are able to edit it.

- Events Calendar Page: This page displays a calendar to the user which shows the different events that our app is able to host. The user can click on different days in order to get to different events. If there are no events for the selected date, the user is prompted to create an event for that day.


- User Profile Page: If the user clicks on the profile page on the navbar, they will be presented with this page showing their information as it appears to others, their interests, and the groups they are currently a part of. They are able to edit their profile information and interests from this page. If they hit the settings button in the appbar, they will then go to the settings page listed below.

- Settings: This is the page that the user will see if they want to change their personal preferences related to the application. As of now, the settings page has a working dark mode switch and a working logout button.

- Dark Mode: Our application implements a work-in-progress dark mode in which the user is able to change the preferences of their application theme within the settings page. The application will then invert colors to a different theme.



- Friends List Page: This page lists the user’s current friends. They can also tap to direct message them from this page.

- Notifications and Friend Requests: Users are now able to send and view friend requests in their profiles. They can view and accept these in the notifications page.




- Group Chats: Every group now has a chat associated with it that allows the user to send messages to their peers. They are also able to see the person who sent the message and click on their profile if need be.



Privacy Policy
To view our Privacy Policy, please visit this site.
Installation
Go to this github repository, click on the green Code button, and click Open with GitHub Desktop.
Next, open IntelliJ then open a new project and select connectuni from your files.
Finally, open the terminal and type:
flutter run
Development Status
Our application development is split up into the following sections:
Evaluation Process / Usability Testing:
Click here to view our Evaluation Design!
Deployment:
Our application is deployed on the Google Play Store and can be found by searching “com.connectuni.connectuni” in the Google Play Store.
Post-ICS466 plans:
Following our application’s lifecycle throughout our ICS 466 Course, we plan on improving our application based on the Usability Design evaluation feedback.
Our main focus will be on:
- Events not working fully in the current implementation.
- Any image uploading to the application doesn’t work.
- Any group members are able to edit the group information (need ownership property).
There are some other small UI/database changes that we would like to make to at least make sure our application is able to deliver all of the features that the user can see throughout our application.
Depending on how timely we are able to fix these UI changes, we will be attempting to conduct more usability evaluations given the time we have between the fix and the final submission.
There are also some features that we would like to implement past the ICS 466 course that deal with user-retention in our application and giving them a drive to use our application more often.
About Us
Kenji Sanehira

Hey! I am Kenji Sanehira and I am currently a Computer Science senior at the University of Hawaii at Manoa. I would like to apply my knowledge from school related to Computer Science into the workforce. I am also the stage manager for the international-tour of the musical “Peace on Your Wings”. In my free time, I enjoy 3D printing, going to the gym, and playing video games. Learning about mobile application development for ConnectUni has been a really fun and educational experience that I hope to apply skills from in the future. For this application I was able to design the profile and group info pages, create the ConnectUni logo, implemented the Events Calendar, create form pages for creating and editing objects, as well as implemented our own version of a direct messaging / group chat program.
Contributions
- Created and designed the profile and group info pages.
- Created the ConnectUni Logo and Splash Screen.
- Implemented Events Calendar and dark mode switcher.
- Created forms for creating and editing users and groups.
- Implemented our own version of direct messaging / group chatting.
Click here to view Kenji’s LinkedIn Profile
Michelle Ho

Hi everyone! My name is Michelle and I’m currently a senior Computer Science student pursuing my B.S. degree. I’d describe myself as a competitive person who loves to stay active. Whether it be sports or puzzles, I find myself competing with family and friends all of the time. With that said, I welcome all sorts of challenges one may have! I’m glad to be a part of a friendly team working together on the ConnectUni project.
Contributions
In this project, I was able to learn about the Flutter framework through:
- Creating the initial Login/Signup pages with manual authentication from Riverpod
- Standardizing mock databases (UserDB, MessagesDB, etc.)
- Ensuring routing works properly - enable a “back arrow” only when desired
- Fixing general bugs (EX: broken group chat page when a user leaves a group)
I was also able to learn about the deployment process as I was in charge of deploying our application to the Google Play store.
Michelle’s LinkedIn Profile
Raphael Bumanlag
.JPG)
Aloha! I am Raphael, and I am a senior studying for my B.S. in Computer Science. I am an aspiring software engineer and desire to work as a backend developer. I enjoy surfing, rollerblading, and weightlifting on my free time. I consider myself to be a very social student which is what drives me to develop a mobile app that enables other students, especially students who are less social or students in a new environment, to connect with other students in similar classes or interests!
Contributions
- Designed the mock-up for searching for groups/people, group chat page, and the friends list page then later implemented those mock-up pages.
- Implemented the navigation bar and the navigation functionality between the multiple search pages, also implemented the search for events pages.
- Helped design and development of the data structures of our app (Users, Groups, Events, Messages, Chats, Notifications).
- Developed state management solutions to our app using riverpod for the search and filter functionality on the multiple search pages.
- Designed and developed the profile page that displays other users.
- Migrated the entire app from using our local database to using Firebase by updating all current Riverpod providers.
- Helped with the development of our app’s chat ui.
- Implemented friend requests and direct messages between users.
- Implemented the functionality for a user to delete their own account.
This project introduced many learning opportunities in the development of mobile applications and also development in general as well.
If I were to highlight one take away from this project, it would be learning state management solutions for mobile applications using Riverpod.
Raphael’s LinkedIn Profile
Jiahui Liao

Hi! I am Jia, a senior studying Computer Science at University of Hawaii at Manoa. I am also the coding officer for the Game Development club as well as marketing manager for the Association for Computing Machinery (ACM) at UHM. I like to draw, crochet, and play video games in my free time. I hope to learn skills that I can apply in the future and have fun doing it. By working on ConnectUni, I hope to support students to build a fun and lasting community for themselves.
Contributions
- Creating initial pages including create event, create profile, direct message page and chat screen.
- Standardizing mock databases (ChatDB) and implementing the events provider.
- In the final stages of the app, I implemented events (edit events page, event forms, and updating event info once a user joins)
- Implemented FlexColorScheme to allow for dark mode and light mode.
- Fixing general bugs (EX: routing between pages, UI)
Jia’s LinkedIn Profile