Last fall, I interned at Citizens Bank for my WPI graduation capstone! I led a hybrid team of 5 interns from WPI—3 developers, 1 data scientist, and 1 business analyst. We worked alongside an existing Citizens team for 8 weeks. We were guided by their managers, but we ran our own sprints.
React
Postgres
Express.js
Tailwind.css
Turborepo
Datadog
2024
Citizens Bank was migrating customers to their open banking API's. Open banking is the transparent sharing of a customer's financial information, usually to let them connect their bank accounts to third-party fintech apps. If you've ever used Venmo, Chime, or Robinhood, you've used open banking!
In open banking, banks must develop standardized API's and OAuth flows to make customer info available to fintech apps. Supporting open banking is crucial to stay relevant in a modernizing financial landscape.
Many Citizens customers had problems, like bank accounts not showing up in Chime or their OAuth consent flow glitching. Citizens had no ideal tools to debug a customer's open banking configurations, but rather a tedious process spanning different departments. Our solution was to create a dashboard to aggregate a customer's info, accounts, and fintech configurations in one place, to speed up customer support.
We employed agile methodologies by doing regular stand-ups, planning, demo's, retro's, etc. Our team met regularly with our stakeholders to discern direction and demo our progress. Retrospectives were super helpful—we made key changes like setting sprint goals, moving from remote to hybrid, and starting code reviews. We used Bitbucket, Jira, Teams, and pair-programming.
We made initial Figma mockups for our dashboard, but they later lagged behind our evolving specifications. So, I initiated a discussion on UI. We brainstormed new layouts and settled on a final design. I learned to use Figma's frames, auto layout, components, and scroll behavior. Figma is awesome!
Leadership is dynamic. It wasn't my explicit responsibility to lead the team in UI, but I saw the need and stepped up. I led throughout the project, running meetings and tracking key features. I have a passion for understanding the larger context behind my work. I used that to drive our design and feature decisions to provide true value to Citizens!
Our dashboard aggregated customer information. An employee can input a customer's ID, then view their fintech apps, accounts, and information to debug any issues.
Our backend obtained customer info from internal mainframe API's. We also queried a Postgres database that stored a user's history of app integrations. We used Postman to test the Citizens mainframe and our own endpoints.
We integrated the info on a frontend of React Router/React Query/Shadcn/Tailwind. We used React Router as a declarative routing library. I learned to set up index routes and route parameters. I also implemented route validation and redirects for customer ID's. This was challenging but satisfying! Shadcn's built-in accessibility and easy customization was super nice. Turborepo worked great too!
Our dashboard simplified customer support, retaining and attracting Citizens Bank customers. We handed off our dashboard to the Citizens team for future iterations and use. We also automated analytics on Citizens' open banking customers, posting statistics into Datadog for better market insights. Our team helped Citizens stay cutting-edge in an evolving, modernizing financial world.
I learn by doing! Take a look at some of my past and ongoing projects.
You can find me on social media! Email form coming soon...
https://github.com/s-leirbag/portfolio