willem.com

Building a product platform

Designing for reusability, flexibility and extensibility

Jan. 31, 2021 -

This month I am leveraging platform capabilities to launch a new product. Over the years I have developed the "Lemmid" platform, a set of building blocks that allow me to swiftly develop new products. Designing a platform takes some extra considerations, but if you follow some simple rules you can do it yourself!

What is a platform?

Simply put, a platform is something that you can build upon. The key thing that separates a platform from a simple product is that the platform can do (or become) other things that were not originally envisaged at the time of its initial design.

A Duplo brick is can be so much more than just a brick
A Duplo brick is can be so much more than just a brick

Modern smartphones with their hardware capabilities and respective app stores can be considered platforms. The platform enables all kinds of originally unforeseen functionality by enabling developers to use the platform's capabilities in novel ways and in new combinations.

New combinations can create novel products
New combinations can create novel products

Reusability, flexibility and extensibility

If you're designing a platform you must take special consideration for reusability, flexibility and extensibility. In a sense you're designing for an unknown future. To understand how to design a platform it is a good idea to have a look at Duplo bricks.

Duplo brick design is brilliant
Duplo brick design is brilliant

The simplicity of a Duplo brick is deceptive, yet the design is incredibly brilliant as it enables:

These three design principles enable the Duplo bricks to become a platform, enabling the creation of new things. If you're designing a platform you can think of these Duplo bricks. The components you create must support the "platform principle".

Building upon a platform - the coloured blocks could be imagined as products upon a platform foundation
Building upon a platform - the coloured blocks could be imagined as products upon a platform foundation

The best way to design a platform is to focus on a single brick. It will be the elementary piece of your platform, imagine how it can connect to other pieces and how you'll standardise that (inter)connection. If you get this right, you'll be amazed how easy it becomes to incorporate new and novel ideas.

A funky new and exciting idea
A funky new and exciting idea
If your platform design is good - adding new and exciting pieces to it should be child's play (and thus, a lot of fun!!)
If your platform design is good - adding new and exciting pieces to it should be child's play (and thus, a lot of fun!!)

Lemmid

Over the years I have developed the "Lemmid" platform, it is a set of digital building blocks that provide a foundation for pretty much any product I develop. This includes apps, websites, webshops and even games!

The Lemmid platform is the foundation for the products that I build on top of it
The Lemmid platform is the foundation for the products that I build on top of it

The platform is designed as a set of micro services that share a common interface and design principle. Each piece is "unaware" of its siblings in terms of design: they're locally scoped and as simple as possible. They can only connect to each other using a standardised protocol that I designed to be as simple as possible, too.

For instance, there is a "Lemmid Bill"-block that is capable of sending bills. To "whom and what" is unknown for this block, other pieces can use the "Bill"-block send digital invoices. It can be reused and it works for invoices with things on them that I haven't even imagined yet.

Another example is the "Lemmid Manager"-block that is capable of managing content. It is used in multiple ways by different products that I created. Sometimes it is used as a website content management system and sometimes it is used to manage a product catalog (driving webshops). It is capable of managing content for sites and apps that I haven't created yet!

Leveraging the platform's capabilities

The food ordering app, known as "Lemmid Store", that I created on top of the Lemmid platform leverages its capabilities by using the individual building blocks to:

From signup to product: automated onboarding of Lemmid Store is enabled by leveraging the Lemmid platform's capabilities
From signup to product: automated onboarding of Lemmid Store is enabled by leveraging the Lemmid platform's capabilities

Conclusion

Take a moment to consider if you're building just a product or if it could become a platform by itself. If the latter is true, you may be wise to design for the future and embrace reusability, flexibility and extensibility.

"I love it when a plan comes together" is exactly what I think if I am able to leverage my platform's capabilities. Launching new products and being able to utilise the power of existing building bricks is "nice", to paraphrase the same Hannibal Smith from the A-team.

When the design comes together - great products appear: Harry van de Laar showing Lemmid Store straight from the kitchen!
When the design comes together - great products appear: Harry van de Laar showing Lemmid Store straight from the kitchen!

Did you enjoy this post?

If you found this content useful,
consider showing your appreciation
by buying me a coffee ❤️😋:

Reach out to me on :

@wlmiddelkoop

Latest Stories

all CloudCreatingCreativityDesignLemmid StoreProgramming

Articles (155)