Need someone to lead product management at your software company? I build high-craft software and the teams that build it. I'm looking for my next opportunity. Check out my resume and get in touch.

This is the blog of Adam Kalsey. Unusual depth and complexity. Rich, full body with a hint of nutty earthiness.

Software Management

The danger of doing too much

Deane asked his readers how to provide clients with an easy way to update a small portion of a static site. His particular example is a company who keeps adding and removing locations from their "Where to Buy" list. Apparently he’s got a lot of sites that need some sort of simple updates but don’t warrant a lot of custom programming because he’s toying with the idea of building a application framework that would let him handle these mini apps easily and asks his readers for ideas.

One person suggests using Wordpress or another lightweight CMS to manage these pages. Deane responds

This is great for things that fit that data model, but what about things that don’t? What if they want to maintain a list of Supreme Court cases, complete with about 10 extra fields of data.

I suggest Deane would probably want to start looking at a custom web app at that point. The stated goal of the framework is to allow a simple customer-editable section without requiring lots of custom programming. The list of Supreme Court cases sounds more complex than that.

Developers run the risk of doing too much when they spec an application. They start looking at all the possible edge cases for their app and trying to incorporate them. This leads to a sort of analysis paralysis where the design becomes so complicated that nothing gets built.

Start simple. Look at the problem you have and solve it. Don’t start thinking about how this isn’t going to solve X or Y. Solve one problem and iterate. Another case comes up that doesn’t fit in? Iterate. Design your framework to be flexible enough to handle iterations, but don’t over-design. You’ll never get anything done that way.

Be simple.

And for Deane’s original problem of letting a customer update a list of locations without requireing lots of validation routines and such, I’d suggest something simple. Give them a text field that overwrites a file. The web page reads that file and displays it. Perhaps add Markdown or Textile processing to the file if they want fancy formatting options. Five minutes of programming work and the customer’s happy.

Recently Written

Should individual people have OKRs?
May 14: A good OKR describes and measures an outcome, but it can be challenging to create an outcome-focused OKR for an individual.
10 OKR traps and how to avoid them
May 8: I’ve helped lots of teams implement OKRs or fix a broken OKR process. Here are the 10 most common problems I see, and what to do instead.
AI is Smart, But Wisdom Requires Judgement
May 3: AI can process data at lightning speed, but wisdom comes from human judgment—picking the best imperfect option when facts alone don’t point the way.
Decoding Product Leadership Titles
Mar 18: Not all product leadership titles mean what they sound like. ‘Head of Product’ can mean anything from a senior PM to a true VP. Here’s how to tell the difference.
What branding can teach about culture
Jan 8: Culture is your company’s point of view in action—a framework guiding behavior, even in the unknown. You can’t copy it; it must reflect your unique perspective.
Think Systems, not Symptoms
Dec 15: Piecemeal process creation frustrates teams and slows work. Stop patching problems and start solving systems. Adopting a systems thinking approach helps you design processes that are efficient, aligned with goals, and truly add value.
Your Policies Aren’t Your Culture
Dec 13: Policies guide behavior, but culture is the lived norms and values of your team. Policies reflect culture -- they don’t define it. Netflix’s parental leave shift didn’t change its culture of freedom and responsibility. It clarified how to live it.
Lighten Your Process Burden
Dec 7: Everyone hates oppressive processes, but somehow we keep managing to create them.

Older...

What I'm Reading