Newer Version Available
Configure Components for Lightning Experience Record Home Pages
Before your component can work on a record page in Lightning Experience, configure the component so it works in Lightning App Builder. See Configure Components for Lightning Pages and the Lightning App Builder for more information.
Once your component is compatible with Lightning App Builder, use these guidelines to adjust it so it works on record pages in Lightning Experience.
Record pages are different from app pages in a key way: they have the context of a record. To make your components display content that is based on the current record, use a combination of an interface and an attribute.
- If your component is available for both record pages and any other type of page, implement flexipage:availableForAllPageTypes.
- If your component is designed just for record pages, implement the flexipage:availableForRecordHome interface instead of flexipage:availableForAllPageTypes.
- If your component needs the record ID, also implement the force:hasRecordId interface.
- If your component needs the object’s API name, also implement the force:hasSObjectName interface.
force:hasRecordId
Useful for record page components. Implement this interface if you want your component to receive the ID of the currently displaying record.
1<aura:attribute name="recordId" type="String" />The record ID is populated only when you place the component on a record page. In all other cases, the record ID isn’t populated, such as when you create this component programmatically inside another component.
force:hasSObjectName
Useful for record page components. Implement this interface if your component needs to know the API name of the object of the currently displaying record.
This interface adds an attribute named sObjectName to your component. This attribute is of type String, and its value is the API name of an object, such as Account or myNamespace__myObject__c.
1<aura:attribute name="sObjectName" type="String" />The sObjectName attribute is populated only when you place the component on a record page. In all other cases, sObjectName isn’t populated, such as when you create this component programmatically inside another component.