Have a naming convention.
Components, their properties, and their values should have a consistent naming convention. For example:
- Component names are uppercase, with spaces between words.
- Property names are capitalized.
- Property values are lowercase.
data:image/s3,"s3://crabby-images/eb559/eb55916a7d19a194d9086990955bce1c73dc11ce" alt="Consistently named components in Figma"
data:image/s3,"s3://crabby-images/d7839/d78398148ea4e25de7d7d2fd7ed0d9b2a5a3d2d1" alt="Inconsistently named components in Figma"
data:image/s3,"s3://crabby-images/bf644/bf64403fc238665fb8181d23d22ce46a2b2d6bd2" alt="Consistently named properties in Figma"
data:image/s3,"s3://crabby-images/3d791/3d79141fde350828f0a042731ebd03e2e4bf6b69" alt="Inconsistently named properties in Figma"
data:image/s3,"s3://crabby-images/31f26/31f2680440e237e19c4f0698db96c9df5ca7a8c5" alt="Consistently named property values in Figma"
data:image/s3,"s3://crabby-images/4f1c6/4f1c64bb9c005ffc60c91df03d0279439a50e3b5" alt="Inconsistently named property values in Figma"
Naming convention should also apply to:
- Hidden components. For example, you can choose to use a dot as prefix, keep words lowercase, and separate them with dashes.
- Deprecated components. For example, you can add "DEPRECATED" before component name.
data:image/s3,"s3://crabby-images/dbb2f/dbb2fc82a4545c3480a09d918006fa4255029f9b" alt="Consistently named hidden components in Figma"
data:image/s3,"s3://crabby-images/aa25b/aa25b60b8a7f0bc9cb6621bbbfcccbb504fecb2a" alt="Inconsistently named hidden components in Figma"
data:image/s3,"s3://crabby-images/a7964/a7964fefe2542a6cfce66bbcf38b79976a071ceb" alt="Consistently named deprecated components in Figma"
data:image/s3,"s3://crabby-images/3f3a7/3f3a7691c78d45fa8a421de56cb695c3ed0a0199" alt="Inconsistently named deprecated components in Figma"
Put properties in a logical order.
Top-down order of component properties should match the reading direction of the component.
data:image/s3,"s3://crabby-images/6606f/6606f4a1c27762e79a7f568533c265389361d34b" alt="Using toast component in Figma as an example"
data:image/s3,"s3://crabby-images/928a4/928a4f2ab9a49689d72b0b88c56204e139624abd" alt="Toast component properties in Figma ordered left to right"
data:image/s3,"s3://crabby-images/aa892/aa89277c4c91bc8ce8a902390763cdc99aca1dbe" alt="Toast component properties in Figma ordered randomly"
Favor boolean component properties over variants.
Use boolean properties for toggling the visibility of component layers. This will reduce the component size and make it much more manageable.
data:image/s3,"s3://crabby-images/89aeb/89aebb2ab20017a34958c13254920d67be0e71c2" alt="Toast component has 40 variants instead of 5"
data:image/s3,"s3://crabby-images/043d4/043d46db6813d54eecf22cad6465fe86140fd3c7" alt="Toast component properties using booleans"
data:image/s3,"s3://crabby-images/b4a6f/b4a6f5dd639f5f13627b90b2315c9f7fbc602189" alt="Toast component properties using variants"
Name your layers.
All component layers should have names. While semantic names are best, it it's okay to have something as simple as "container" or even "frame" (just not "Frame 1453583").
data:image/s3,"s3://crabby-images/63e66/63e6677ca9efe3b8e107918c3d96288295149552" alt="Component layers with semantic or cleaned up names"
data:image/s3,"s3://crabby-images/a0219/a02198510600da38ad3f5592372e2848fe2ea0c6" alt="Component layers with default frame names"
Don't nest components in unnecessary frames.
Placing components inside (unnamed) frames can make it more difficult to use the component, because it creates additional nesting in the Assets panel.
Of course, you should still use this feature intentionally :)
data:image/s3,"s3://crabby-images/2227d/2227d933cade855e7b508d3391f92c798b5ae146" alt="How a toast component looks in the Assets panel when placed inside a named section"
data:image/s3,"s3://crabby-images/c0281/c0281b646dcb21c5064bb3a22ac6b02fdb266e43" alt="How a toast component looks in the Assets panel when placed inside an unnamed frame"
Don't create recursive components.
Don't use an instance of a component to create another variant of that component. This creates a poor experience for everyone who maintains and uses the library.
data:image/s3,"s3://crabby-images/d1a64/d1a642e871f7d3cdad871a04baf9a5c9139ebc15" alt="A recursive component"
Set most commonly used variant as the default one.
Place the most commonly used variant in the top left corner of the component set to make it the default one. This will greatly reduce the amount of time designers spend on component configuration.
data:image/s3,"s3://crabby-images/f2ff2/f2ff22d9dcdee066592d6b8ca6490d0d0aa8c1d3" alt="Most commonly used button variant is in the top left corner of the component set"
data:image/s3,"s3://crabby-images/1dd0b/1dd0bd23461d64f0f6afc4b8f9840e281942e082" alt="Not as frequently used button variant is in the top left corner of the component set"
Make icon components obvious.
You can add "Icon" at the end of the name. This makes it easy to differentiate it from a different component with a matching name:
data:image/s3,"s3://crabby-images/a4edd/a4edd0caf22aaeac43b893b5ad44bb76dd10b685" alt="Menu and menu in the Assets panel"
data:image/s3,"s3://crabby-images/9c683/9c6832f564a48b3fccedfa23f855798f0674ac4a" alt="Menu icon and menu in the Assets panel"
This becomes even handier in the instance swapping settings (since the thumbnail is much smaller that it is in the Assets):
data:image/s3,"s3://crabby-images/16117/1611770ae80cd3624311318993ca5036a0a7502c" alt="Menu and menu in the instance swap settings"
data:image/s3,"s3://crabby-images/8f99e/8f99e81cd11ef72c7906cc075a5a55b03eda9140" alt="Menu icon and menu in the instance swap settings"
Don't create unnecessary components.
Not everything has to be a (sub)component, especially when it comes to component parts. The selection tool makes it easy to update component parts without resorting to creating another (most likely hidden) component.
data:image/s3,"s3://crabby-images/78704/78704c560fe9e3c00a5f7ae123286b87eb038a59" alt="Using a selection tool to select a matching part of all toast componenent variants"
data:image/s3,"s3://crabby-images/0eebc/0eebc38d6f7c96826bffa6572026e6dc6a74748b" alt="Extracting a part of the toast component as a subcomponent"
Don't create unnecessary documentation.
The best way to learn about a component is by playing with it. Adding documentation inside Figma is usually not effective, because most designers don't keep the component library file open as reference. They primarily interact with the components through the Assets panel. Adding unnecessary documentation also creates more unnecessary management work for the library maintainers.
If you want to have documentation, the best way is to have a simple website that everyone at your company can access.