Element naming
Element naming is the hardest when it comes to standardization for Bubble development. In this document, we covers not just recommendations for element naming but also element types break-down. These types come from creative ways that Bubble developers use the elements to their fullest to demonstrate complex behaviors.
TL,DR:
Groups
Structural groups: Use Header, Body, Footer, Section for the corresponding groups.
Regular groups: Use
{Group type} {Group name}
like usual. For example: Group Testimonials, FloatingGroup Sidebar, Popup Deletion Confirmation.Sub groups: Use
[{Parent's name}] {Group type} {Group name}
. For instance:Parent group:
FloatingGroup Nav
Sub group:
[Nav] Group Menu
RepeatingGroups: Use
RepeatingGroup {Data type}
orRG {Data type}
. For instance:RG Comment
.
Reusable elements
Reusable elements should be named like pages, with type: [{Reusable type}] {ReusableElementName}
. For example: [Drawer] UserDetails
Common reusable types include:
Container: A big component that contains a lot of elements and logics inside, similar to an organism in atomic design, mainly used for breaking the apps into smaller parts.
Drawer: Either a popup or floating group that displays data as a drawer.
Dialog: A popup with CTAs.
Subpage: For groups used in single-page behavior.
Workflow: Invisible components that encapsulate workflows only.
Component: Small components, like a simple like button with logics that manage the number of likes.
Visual elements
Non-dynamic elements: You should keep the element type first, and then its name, like usual:
{Element type} {Name}
. For instance: Button Submit Feedback.Dynamic elements: Use
{Element type} {Data field}
or{Element type} {Operations}
. For instance:Text username
orText firstName + lastName
.
Input elements
Input elements should reflect the data they are changing: {Element type} {Data field}
or {Element type} {Data type/Data field}
. For instance: Input username
or Input User/username
.
Custom states
To differentiate from data field, use snake_case for custom states. Other than that, custom states should be similar to a data field's name.
Notation of state, data & clickable
<S>
or<State>
for elements with custom states.<D>
or<Data>
for elements with custom data sources (parent elements only, no need to mark child elements that inherit the data).<C>
or<Click>
for non-input elements that are clickable (e.g. texts, groups).
Example: <S> Group Users
Notation of element grouping
[Tag]
should be used to group elements together.
Notation of order
Groups, data fields, option set fields, etc when related to ordering (e.g. steps in an onboarding process, indicated by an option set) should come with a number indicator (no_
) before the name.
Example: 1_onboardingStep
; 2_onboardingStep
For further analysis, explanations and examples, please check the below documents out.
Last updated