Proof of Concept - What I learned from software engineers
What I learned from software engineersIssue 88: Design and Engineering should not be Cats vs. Dogs
I spent this past week in New York City, when it is Ramadan, Passover, and Easter all in the same weekend—the three-peat of monotheistic religions. The trip on this weekend was not by design but poor planning on my part. Serendipitously it thematically aligned with my intention of creative renewals and rejuvenation. It’s natural to reflect on the past when you catch up with old friends or coworkers. In one conversation, we went way back when I was an individual contributor (IC). It's been seven years since my day-to-day was working on designs and shipping features. When I joined One Medical, I joined as an IC after a break from management. I believe that it should be normalized to switch from an individual contributor or manager, but that’s a different issue for another day. My colleagues often called me "an engineer's designer" since I loved working closely with developers and had an interest in writing code. I intentionally sat by the software engineers in the offices to work closely on design and implementation together. If there is a phrase that I despise more than anything, it’s “design hand-off." I don’t believe in hand-offs. The work is continuous iteration together from idea to shipping. In this issue, I’ll share some of the myths of software engineers and lessons I learned from incredibly smart programmers. Debunking myths of software engineersLike designers, not all engineers are built the same. That said, there are some generalizations about developers that have become stereotypes. I’d love to de-bunk it with you. Engineers don't care about designI cannot think of a single engineer who I ever worked with that didn’t care the product they worked on looked like rubbish. Many engineers value design—some have more of a knack for doing it themselves and others need help from designers. There are a lot of memes about design vs. engineering and I find them very harmful to the credibility of our craft. Some engineers may not have enough information on how the design should be implemented or need further guidance. Sure, you might work with a few engineers who simply don’t care and I argue that the majority do. This is why I believe when a designer understands the material they’re working with, better outcomes can happen because there is more of a common language and you can close the gap on iteration. In this case, the material is code. When you work with a software engineer, show her how you’re thinking of design and ask her what you should learn more about how the code is implemented. Great things will happen. Agile gets in the way of great design workThere is nothing that’s more untrue than saying agile is the reason great design doesn’t get shipped. The reason we might feel is way is because most companies aren’t practicing it correctly—usually a combination of Waterfall and Agile that we like to call Wagile. In fact, one of the principles of the agile manifesto states, “Continuous attention to technical excellence When I worked with an ex-Apple engineer on a new product idea, I got a taste of how good design can be practiced with agility. I remember this engineer, someone who I would later call a good friend and mentor, relentlessly iterated. I was working on designs for the initial interface of the app we’d prototype. As I took a small break, he tapped me on the shoulder and handed me an iOS device. It was the first build of the initial screen I was working on! I was in disbelief how fast he was working. Each build, we’d walk through the interaction, discuss what can be improved and tweaks we could make, and I’d keep working on the designs. When it came time to think deep and explore on areas we couldn’t decide on, I’d work on another track of work while he started building out the data model or something else that could be picked up. To this day, this type of collaborate is my favorite way of working. Understanding the customer is for designers and researchersThere’s often a belief that engineers don’t care about the end customer—that all they care about is what tech stack the company is using. Software engineers want to make an impact in a positive way—building things that benefit humanity. When I was at One Medical, our software engineers shadowed a lot of customer visits and were involved with Design and Research. I recall a trip when Eliza, one of our software engineers, observed a bug in the workflow as one of the clinicians was using the product. On her flight home to San Francisco, Eliza was able to submit a pull request and fixed the bug. Lessons I learned from engineeringThough this list does not include all lessons I’ve learned from software engineers and engineering managers I’ve worked with, here are the five most impactful lessons. Breaking down work is good planningI vividly remember the first time I worked with an engineer to break down work. In this case, it was my co-founder Adam as we were building a product. We created the feature sets and wrote the user stories together. It was so eloquently broken down into the pieces of functionality, edge cases, and prioritization of where to start first. After many revs of building products, it's almost muscle memory on what's needed to build out an authentication workflow or CRUD actions in a profile page. Understanding how to break down work helps with planning and sequencing. It’s beautiful to see all the aspects to create a piece of functioning software—never gets old. System design for scale and evolutionDesigning software as systems that can scale or evolve is an important skill for designers to have, especially as they grow in their careers. The more senior one gets, the more you’ll likely touch the architecture of how things are created. Understanding some basics such as the difference between monolithic apps and micro services helped me consider implications of certain design decisions. We might forget that the idea of reusable component software is something that comes from engineering. Working with software engineers on system design taught me to consider how the product evolves over time and not only the current manifestation of it. Intention setting keeps work on trackJeff was an engineering manager who I previously worked with. He was so skilled at intention setting, not only for the team he managed, but himself. In our 1:1s, he’d have the entire week mapped out. Certainly, plans change, but if you can set intention that is predictable, it makes you and your team more effective. After setting intentions, using standup and other rituals effectively helped course correct—like having a coach on the sidelines. With the busyness of the world, I’m finding intention setting important to make time for—blocking out my Monday mornings to plan out the weeks of work. Prototyping and spike projects are forms of “design to define”If there was one favorite phase in the product development process for me as an IC, it was product discovery—the art of identifying new opportunities and prototyping your way there. I call it “design to define” where you create prototypes and spike projects to help make decisions. In addition to this work being impactful, I personally think it’s so fun. One of the best projects I worked on was an app for a consumer startup making a lot of headlines right now. The team was only me on the design side and two engineers, and we prototyped the crap out of it to start—building proof of concepts to fund the idea for this particular client. Working this way taught me to get deeper in the code and how prototypes could be more expansive than clicking through screens. Quality starts with performance and usabilityDesigners are responsible for ensuring teams ship a high quality product. Though the interface is important, quality starts with performance and usability. Working with engineers showed me the importance of optimizing for performance, such as load management of data and areas that can result in delays in the product experience. It doesn’t matter if you have a pixel-perfect design if the app crashes or lags in certain area. I learned to sweat the details of the interface, such as accessibility, optimal tap targets, and looking at latency as a metric to improve. I also feel spoiled that I worked with some of the best QA engineers throughout my career—one who recently joined Webflow and I’m so excited to work with her again! Building software not “us vs. them,” it’s only “us”The relationship between designers and engineers is often framed like the rivalry between cats vs. dogs. When cats and dogs work together, incredible things happen. I recommend three books about engineering that you might enjoy:
To all the software engineers and engineering managers I’ve worked with in my career, thank you for making me a better designer and product builder. Tweet of the weekCongrats, Dezzie on being selected as a juror on Core77’s Design Awards in the field of Interaction Design! I'm humbled to have been chosen to be on this year's jury for the @core77 Design Awards in the field of Interaction Design 🥰🍩.
@RaquelDesigns, @romellogoodman, @Rswedenborg, @druesclues, @ruihai_, Jordan Shade, and @thedezzie are ready to be 🤯 away by all your work! Hype linksInteresting links I read this week or references in this issue:
1 One of the big reasons I believe RSS is the most important internet technology in the world Enjoy this newsletter? Please consider sharing it with friends, or subscribing if you haven’t already. I appreciate it! Sincerely, DH |
Older messages
Networking for introverts
Sunday, April 10, 2022
Issue 87: Building career capital when people isn't your thing
Gratitude as a designer
Sunday, April 3, 2022
Issue 86: There is a lot to be thankful for in this profession
The creativity of business
Sunday, March 20, 2022
Issue 84: Why creative techniques are crucial for business innovation
Unpublished and unfinished works
Sunday, March 13, 2022
Issue 83: It's okay to leave work in the cutting room floor
Reading, Researching, and Writing on the iPad
Sunday, March 6, 2022
Issue 82: A look into a digital workflow for thinking and writing
You Might Also Like
2024 magic moments
Sunday, December 22, 2024
Issue 225: The year from my personal lens ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
Planning mode
Friday, December 20, 2024
Lessons from our first-ever annual planning sprint ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
We Co-Sign This AD100-Approved Trend
Thursday, December 19, 2024
View in your browser | Update your preferences ADPro Emboldening the Bath Marble, marble, everywhere, and every drop is chic. According to AD100 designer Jake Arnold, “material drenching”—that is,
177 / Keep calm by listening to these ambient sounds
Thursday, December 19, 2024
Product Disrupt Logo Product Disrupt Half-Monthly Dec 2024 • Part 1 View in browser Welcome to Issue 177 Lately, I've been driving a lot of inspiration from the things I see in real life. The range
The Year in Color: Hella Jongerius, Mocha Mousse, and More
Thursday, December 19, 2024
View in your browser | Update your preferences ADPro Color Our World Since the summer, AD PRO has kept its finger on the pulse of color predictions. Overall, the vibe right now is down to earth,
🐺Get Media Features in 2025
Thursday, December 19, 2024
A BIG Wolf Craft announcement!! ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
Small teams
Thursday, December 19, 2024
Issue 224: Why the mentality of lean and small always wins ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
Accessibility Weekly #427: The Myth of Accessible Components
Thursday, December 19, 2024
December 16, 2024 • Issue #427 View this issue online or browse the full issue archive. Featured: The myth of 'accessible components and done' "Think you've solved all your
Here's what you missed...
Thursday, December 19, 2024
Get press for your business in 2025...here's how. ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
Kelly Wearstler on the Rigorous Routine That Keeps Her Churning
Thursday, December 19, 2024
View in your browser | Update your preferences ADPro Kelly Wearstler has expanded her content empire. Earlier this month, the AD100 Hall of Fame designer announced the launch of Wearstlerworld, a