Cisco PX Cloud
Cisco UX Engineering Internship
Team
1 Manager, 1 Product Owner, 6 Engineers, 4 Designers
Duration
May 2023 - August 2023
Role
UX Engineer
TASK
“Analyze PX Cloud for pain points and UI improvements”
I took this prompt and spearheaded a self driven project using the resources my manager offered me to improve the platform. From gathering information for user research across teams, to implementing my solutions with the engineering team, my manager gave me free reign to create something truly impactful
“Go crazy with it!” -My Manager
My manager briefly explained the intern project he designed for me that summer, giving me a prompt and introducing me to the platform and my team. His goal was for me to turn something vague into something concrete, to gauge how much I could do with the little information given to me, to navigate ambiguity.
Challenge accepted.
BACKGROUND
What is PX Cloud?
For background, Partner Experience (PX) Cloud is “a portal for Cisco Partners to connect with Cisco and their Customers that includes unified dashboards, Partner Offers, learnings, and more”
It’s a relatively newer platform in comparison to CX Cloud, Cisco’s sister platform that was created to give customers a unified view of their products and services. These platforms are under the CPX org and are used in Cisco’s lifecycle racetrack
Planning
I split this project into two parts: Research/Design and then Implementation. Each part was split into 4 week time frames where I worked with the Design team of PX Cloud and then the Engineering team I was assigned to. Given a short time frame and an overly ambitious mindset, I realized that I needed to break my project down into realistic and achievable steps so I can deliver the most in one summer. One key thing I learned about myself in this process was that I’m very deadline driven and that I need to always have something to do.
RESEARCH
AND DESIGN
One big plus of being an intern is that I add a fresh perspective to an existing product which was the main goal of my intern project. The first thing I did was familiarize myself with the platform, playing around to figure out what was and wasn’t intuitive to me at first glance. I compiled a list of notes for things like metrics, non uniform usage of space, filters, dashboard customization, and then a list of questions about the platform.
I can’t exactly show the visuals of each problem, given that it’s not publicly available, so feel free to reach out for details on my notes~
Immediately after my brief overview I took my questions to the existing design team of PX Cloud to gauge the scope and accuracy of my notes. They walked me through their upcoming v3 updates and shared some UX research reports from past years. With these resources, I had more to sift through in order to align my design ideas with their existing goals.
Since many of the pain points I found were being addressed in the v3 update or had to do with aspects of the product that the designers couldn’t control, I was able to narrow down my ideas using those constraints.
Idea 1: V3 Side Panel
OLD
I ran these ideas with my engineering team who helped me figure out exactly how much work was required to implement certain solutions. Their constraints helped me ideate solutions that, for example, wouldn’t introduce a new common component (requiring approval). This part of the process combined idea iteration with solution feasibility where I was coming up with solutions throughout the conversations in order to understand which problems I could solve in this 8 week span.
My mentor able gave me insight on how to make sure my solutions gave users a uniformed experience, switching from CX cloud to the newer PX cloud. This follows Jakob’s Law in UX which was something I was trying to keep in mind as I was ideating on a platform I had no familiarity with. I planned to solve a problem of non uniform distribution of space by using an existing v3 solution that was implemented in CX Cloud, which I again am unable to provide an exact visual of.
The final idea I had related to the filter types on one of the sections. At the default page, no filter is selected and every result is displayed. Once you click on a radio button filter, there is no way to unclick the button to return to the default stage without clearing all filters. This restricts user control and freedom, so I had to ideate a solution that would fix this.
Honestly, just make it a checkbox right? That’s how you can tell a user they can unclick it! Except… that wasn’t possible. Due to the property of the filters, it wouldn’t allow more than one option to be selected, thus, I wouldn’t be able to program it that way.
The next idea I had was to make the radio buttons unclickable, code exists to make that possible! Except… that’s also not possible. This is because the code for the buttons refer to common components that exist across the organization, so it would break the code to change its behavior, especially for only one filter group.
While on the mockup, I couldn’t create a reset filter group button because that would be a common component I wouldn’t have time to get approval for.
So then what? The final idea I ended up with was an added radio button that would be selected on the default page, so that users understand the buttons purpose and the behavior of radio buttons are preserved and intuitive. The only thing left to do was implement it.
Idea 2: Updated Radio Buttons
1
2
3
4
NEW
A mockup of the new side panel, highlighting the notable changes in format, header, and size without disclosing proprietary information
IMPLEMENTATION
After presenting these ideas to my manager, I had 4 weeks to implement two ideas. Our team worked in 2 week sprints using Jira to follow an Agile Methodology, so I had one sprint for one idea. Working with this huge database was intimidating, to say the least, and I had never worked in typescript or angular.
I was a fish out of water!
Luckily, my mentor Anthony pair programmed with me the whole time and helped me understand the thought and process that each engineer goes through to complete their tickets. I familiarized myself with the devtools and how the code base was organized. One of the key things I realized from this process was that bigger companies have greater tech debt, making it hard to implement solutions as quickly and efficiently as desired. This made it significantly harder to implement a ‘simple extra button.’
My side panel solution was taken up by an adjacent engineering team because v3 updates were starting to move into production, so I worked on developing some design team requests. Yet again, these ‘simple’ requests proved to have a lot more work required than expected.
By the end of my two sprints, I had officially sent a UI improvement to PX Cloud into the August release!