Product Development Culture

How We Work

In this document we’ll go over the cultural values that drive our product development team at Per Diem. But before we get to these values, we want to go over a few things. We want to look at what we are building, why we are building it, and how we operate as a team. This’ll give us a good sense of where our cultural values come from and why they matter to us.

About this document

This document is meant to be used as a user manual for the Per Diem product team. We think sharing it publicly serves two purposes:

  1. It helps the community get a better sense of how we operate.
  2. And, it helps keep us accountable to the standards we set.

This document is a work in progress. If you have feedback on what’s covered here, or have suggestions on what we should add, please let us know.

Background

What is Per Diem

Per Diem is a platform that makes it easy for local businesses to launch their own mobile ordering app. We help coffee shops, farmers markets, restaurants and other SMB's leverage mobile to drive repeat business and recurring revenue. We provide merchants with an iPhone and Android app, a direct integration with Square POS, and we eliminate commission fees to maximize the businesses' bottom line.

Per Diem is a perfect fit for local businesses.

Per Diem is self-service and completely customizable for any business to use, a single store is able to sell a subscription to thousands of their customers with no new operational overhead.

It’s a perfect fit for any business with a loyal customer base.

Our vision

We think every business should be built using Per Diem and we want to create a platform that makes this possible. They should be able to get started in less then 30 minutes when using our platform. As their customers and revenue grow, merchants use our platform to become more profitable and create enduring relationships with their guests that stand the test of time.

Build a platform that local businesses can leverage to boost loyalty

This means that our platform needs to be both:

  1. Easy to get started so that we can onboard new merchants to the platform.
  2. Appealing to a business's customers, allowing them to fully take advantage of their mobile app.
Per Diem embraces a remote work culture. You can work for us and code from anywhere.

How we build products

Building a platform that’s both easy to get started for merchants and appealing to their customers is a challenge. There are a broad number of use cases and each use case needs to be configurable to a specific action (eg: weekly CSA pickup, monthly coffee delivery, restaurant house account). In a sense, the problem space is both wide and deep.

Problems like these are a good fit for hospitality-focused businesses. Businesses that tend to naturally extend the use cases of subscriptions are service oriented businesses that have a loyal customer base.

Customers of subscription businesses are also far more willing to buy additional products from that business, when compared to the typical customer. Whether it is providing tremendous value or offering an exceptional experience. We strongly believe that business owners that adopt a subscription model will create a more loyal customer base while increasing their profitability.

Business owners that adopt a subscription model will create a more loyal customer base while increasing their profitability.

How we implement features

Here’s a rough step-by-step process that we try to follow.

Let’s assume we get a message on Slack or somebody opens an issue on GitHub.

  • Start by understanding what the user is trying to do.
  • If it’s a bug, understand what’s causing it. We don’t need to have a solution, but we need to get all the information required to debug the issue. It’s harder to get the user to send you debug information after they’ve moved on.
  • If it is a feature request, understand what the user is trying to achieve. Listen to their problems, not their solutions.
  • Then we create a document with:
  • Everything that was talked about
  • List of all the places that it’s been brought up in
  • List of all the people that’ve brought it up
  • If the issue has been brought up before, add the new person to the list
  • After we understand the problem, figure out if it’s straightforward to implement or if we need to design a solution.
  • A straightforward solution usually includes bug fixes or features that don’t change the overall design of the product.
  • On the other hand, if the solution isn’t obvious or is a bigger change, we need to make some design decisions (more on this below). For design decisions, get the team involved.
  • Before the group discussion, come up with a proposed solution.
  • If the issue is urgent, don’t hesitate to get somebody’s time. The leadership team needs to be on-call for urgent issues.
  • If the issue is not urgent, you can book a time on somebody’s calendar. Or bring it up in the daily standup or a 1 on 1.
  • We then propose the solution to the user. Preferably with a prototype, and ask the user if it solves their issue.
  • Update the tickets in Linear with the proposed solution.
  • We figure out the priority for this issue and when we are going to work on it. More on this below.
  • If you are working on it right now, tell the people that reported the issue. They are likely to help if you need some additional feedback.
  • Implement the solution in a PR. You can read more about PRs and cutting releases in our CONTRIBUTING.md.
  • If the new feature has a new name or it’s a new option, review the naming with the team.
  • Write a doc for it and add it to the PR. It doesn’t have to be perfect but it needs to be functional. The copy will be reviewed later but the content needs to be figured out upfront.
  • Cut a release. In the release notes mention how to use the feature.
  • Tell everybody that requested it about the release. Mention the version number, so they can upgrade to it.
  • Announce the release in Slack, with a snippet on how to use the feature.
  • Make a list of all the copy and docs changes that need to be reviewed, create an issue and send it to the team.

The key here is that it’s easier to gather the requirements and understand the problem when it’s first reported. Even if we don’t end up implementing the fix right away, users are far more engaged when the issue is first reported. We want to figure out a solution and get it validated by our users as early as possible. And document everything in Linear or a Google doc.

We want to figure out a solution and get it validated by our users as early as possible.

We also want to notify users when we release a fix. It shows them that we personally care. And it makes it more likely that they’ll give us feedback in the future.

How we prioritize what to work on

We have a rough flowchart that we use to prioritize features. This will evolve as the priorities of the team changes.

Is there a user blocked by the issue or feature request?

  • Yes ⇒ Fix it now
  • No ⇒ Is the issue related to a new user’s experience?
  • Yes ⇒ Fix it now
  • No ⇒ Is it a quick change (will take less than 30mins to implement)?
  • Yes ⇒ Mark it as High priority
  • No ⇒ Has it been brought up before?
  • Yes ⇒ Mark it as High priority (bumped up from Low)
  • No ⇒ Mark it as Low priority

So the priorities look like: “Fix it now”, “High”, or “Low”. The “Fix it now” ones are the urgent issues that we work on right away. While the “High” priority ones are the issues that we are currently working on (when there’s nothing urgent). The “Low” priority ones don’t get worked on until we’ve run out of the “High” priority issues. Or they get bumped in priority.

For the “Fix it now” and “High” priority issues, we tell the user the timeline for the fix (today or tomorrow vs this week or next week). On the other hand, for low priority issues we tell them we won’t get to it right away. But ask them to let us know if it becomes a blocker and we’ll bump it up in priority.

While the above flow can seem a bit rigid, there are a couple of caveats. For example, we might prioritize a feature differently:

  • If it’s being requested by a valued merchant or strategic partner
  • If a person that’s trying to contribute to the project needs it
  • If you think we can solve it in a novel way and it can have a big impact

Feel free to pull the leadership team in, if you need any help. We hope that over time you are able to build a better sense of how to prioritize features.

Our design process

As mentioned above, there are some issues that are not straightforward to implement. They require a certain amount of design. These are typically issues that have multiple solutions and it’s not immediately clear which approach makes sense. It’s important that we have cohesively designed products that work well together. We also care about making our products intuitive to use. This means that for some issues we need to put a lot more thought while designing a solution. We employ a “design” meeting to work through this. It usually involves:

  1. Understanding the root cause of the problem we are trying to solve.
  2. Looking at the other examples in the field and understanding their pros and cons.
  3. Weighing the different approaches we can take to solve the problem.
  4. This involves putting together prototypes or demos for the team to evaluate.
  5. It’s much easier to evaluate possible options based on something real.
  6. Making sure that the proposed solution works with the design choices made across our other products.

It’s important that we work through this process on our own, before a design meeting. The rest of the leadership team is there to help you make a decision. And it allows you to get better at making these decisions.

It’s important to work through the design process on your own, before meeting with the team.

It should also be mentioned that it’s the responsibility of the leadership team to not make these meetings a blocker. If a feature needs to be implemented urgently, they are on-call for these meetings.

Naming things

We also like to take care while naming features, config options, props, etc. For anything new:

  1. Suggest what you’d like to name it and why.
  2. Offer two other suggestions and what you like about them.
  3. Post this in the team channel. The rest of the team will quickly vote on them or add their own suggestions.

Coming up with a good name can sometimes be hard. But it’s worth thinking it through, especially for things that can be hard to rename later.

How we operate as a team

The above should give you some sense of how we operate internally as a team. But let’s look at it in a little more detail. We’ll look at it from the perspective of an engineer that’s building our products.

The process of talking to users and building products is the core engine that drives our team. This implies a couple of things:

  • Our product development team is remote, and our customers are primarily based in the US, which means we'll rely heavily on our business stakeholders that are in the field with our customers.
  • For this reason our business and product teams work together in squads when it comes to talking to users, gathering requirements, proposing solutions, implementing them, releasing them, and notifying our users.
  • We want to reduce the number of people an engineer needs to talk to internally to get something done.
  • For the cases where we need the leadership team’s input on design, we want to ensure that the leadership team is always available to provide feedback.
  • We also want each engineer to have ownership of specific parts of the product and manage the roadmap for it.
  • Keep track of the key input and output metrics of the product to drive its growth.

The role of the leadership team is to give an engineer as much autonomy as possible and to make sure the product process is running smoothly.

Cultural values

All of this leads us to our core tenets, our cultural values.

Having a hospitality mindset

We need to remind ourselves that our users are using our products to get their jobs done. While they need help with our products, it’s because there is a bigger purpose to what they are doing. So our mindset while interacting with our users should be helping them get to where they want to go.

We need to have a high degree of empathy for our customers. No issue is too small or too trivial or too dumb. It’s our job to make sure the user is able to do what they want to do through our products.

Thinking as a user and paying attention to the details

While we are trying to help our users build their products we are not merely providing “support” or “services”. We are trying to figure out how our products can do a better job for them. We need to pay attention to the details of their experience. This doesn’t always mean making big changes to our products. It could be something as simple as clarifying some small details in our docs. We need to think as a user and use their feedback to improve the product.

As a team, we rely heavily on our users to guide our product roadmap. So it’s important that as engineers we spend time thinking about all the little details of their experience. This information helps us make better product decisions. And ultimately lets us make something that people want.

Having good taste

A lot of the key products and features that we work on, require us to make design decisions on behalf of our users. In an industry where most solutions are complicated, we need to design intuitive products that are easy to use. It also matters that we use similar design principles across our products, so as to minimize the number of concepts a user has to learn.

We need to have a high personal bar when it comes to design. Design in our case is about all the small decisions we make while creating our products. We need to weigh our options carefully and try to make the right tradeoffs. This also makes our users feel that there was a certain degree of care that was taken while building it.

Moving with urgency

As noted in the product process above, it’s important that we respond in a timely manner and gather feedback quickly. It’s important to capture feedback before the user moves on. Similarly, it’s important to push out features right when they need them.

Moving with a sense of urgency that’s driven by user feedback allows us to delight users, build community engagement, and foster a culture internally that’s exciting to be a part of.

Taking ownership

We want our business stakeholders to help our engineers run the entire product development process. We want them to take on a part of the product and drive the roadmap completely. We want them to select the KPIs, set the goals, and take part in our weekly and monthly reviews as a representative of that product.

We think it’s naturally motivating to be responsible for building something that solves a problem for somebody else. So we want to create an environment where it’s possible to take ownership of that entire process.