Embedding the Iframe

The Display Services iframe enables sales teams to leverage LinkedIn identity and insights without having to leave your application's workflow. This guide describes how to embed the Display Services iframe into your application, and other need-to-know technical details.

Embedding Methods

Embedding via HTML Iframe

The iframe can be embedded in your application by placing it directly in HTML. Here's an example iframe element that can be embedded:

<!-- NOTE: line breaks are added for readability -->
<!-- apiKey, firstName, lastName, email, companyName, crmRecordId, crmOrgId, crmSourceType values are for example only -->
<iframe src="https://www.linkedin.com/sales/widget/profile-matching?
  apiKey=YOUR_CLIENT_ID&
  firstName=Bill&
  lastName=Abrams&
  email=babrams@examplecompany.com&
  companyName=Example Company&
  crmRecordId=3AFXT8CAAY&
  crmOrgId=HV1OX56I8B&
  crmSourceType=YOUR_CRM_SOURCE_TYPE&
  crmType=contact&
  modules=TopCard2,RelatedLeads&
  version=2.1&
  isInlineMode=false
  &sat=Aj2AKAv"
  width="300"
  height="336"
  frameborder="0"
  type="text/html">
</iframe>

One critical advantage of embedding the iframe directly is the ability to specify an ID for the iframe element so that your application can display, hide, and resize the iframe dynamically through JavaScript or CSS.

Note

Directly embedded iframes must have the iframe source URL-encoded. See the example below.

Your actual HTML should contain URL-encoded parameters, including ampersands:

<!-- apiKey, firstName, lastName, email, companyName, crmRecordId, crmOrgId, crmSourceType, crmType, sat values are for example only -->
<iframe src="https%3A%2F%2Fwww.linkedin.com%2Fsales%2Fwidget%2Fprofile-matching%3FapiKey%3DYOUR_CLIENT_ID%26firstName%3DBill%26lastName%3DAbrams%26email%3Dbabrams%40examplecompany.com%26companyName%3DExample%20Company%26crmRecordId%3D3AFXT8CAAY%26crmOrgId%3DHV1OX56I8B%26crmSourceType%3DLINKEDIN_PROVIDED_CRM_SOURCE_TYPE%26crmType%3Dcontact%26modules%3DTopCard2%2CRelatedLeads%26version%3D2.1%26isInlineMode%3Dfalse%26sat%3DAj2AKAv" width="320" height="336" frameborder="0" type="text/html">
</iframe>

Customizing Experience: Components and Display Modes

The iframe's path and query string define what Sales Navigator functionality can be experienced by the user. All instances of the iframe are rendered in the context of leads (LinkedIn member profiles) and accounts (companies). For each context, there are a number of components that you can select to render individually or with the Top Card, which describes the lead or account being displayed.

Here is an example iframe in Classic Mode with profile Top Card (left) and Icebreakers, Get Introduced, and Related Leads components(right):

iframe in Classic Mode with multiple modules

You can see screenshots for all the components available on our Leads Module References and Accounts Module References pages, with accompanying descriptions of the content included in each component.

Inline and Classic Modes

To give you the freedom to design workflow experiences when minimal space is available in your application, Display Services offers Inline Mode for components that are rendered individually. You can get the Inline Mode experience by specifying isInlineMode to true in the query parameters. Inline Mode offers a few benefits over the default Classic Mode:

  • It removes the header and footer border elements
  • It displays more content in less space
  • Prevents redundant branding when more than one iframe is embedded on a page

Here is an example rendering of the Top Card for a profile in Inline Mode:

Profile Top Card in Inline Mode

Loading Profiles or Accounts

You can choose to display information about profiles or accounts by specifying so in the path when embedding the iframe directly. Here is an example iframe src requesting the profile Top Card:

<!-- NOTE: line breaks are added for readability -->
<!-- apiKey, firstName, lastName, crmRecordId, crmOrgId, crmSourceType values are for example only -->
<iframe src="https://www.linkedin.com/sales/widget/profile-matching?
  apiKey=YOUR_CLIENT_ID&
  firstName=Abraham&
  lastName=Lincoln&
  crmRecordId=3AFXT8CAAY&
  crmOrgId=HV1OX56I8B&
  crmSourceType=YOUR_CRM_SOURCE_TYPE&
  crmType=contact&
  modules=TopCard2&
  version=2.1&
  isInlineMode=false&
  sat=Aj2AKAv"
  width="300"
  height="336"
  frameborder="0"
  type="text/html">
</iframe>

Note

The query parameters available for searching change depending on whether you are loading the lead or account paths.

Here is an example displaying the company Top Card instead of the profile Top Card:

<!-- NOTE: line breaks are added for readability -->
<!-- apiKey, name, website, crmRecordId, crmOrgId, crmSourceType values are for example only -->
<iframe src="https://www.linkedin.com/sales/widget/company-matching?
  apiKey=YOUR_CLIENT_ID&
  name=LinkedIn&
  website=www.linkedin.com&
  crmRecordId=3AFXT8CAAY&
  crmOrgId=HV1OX56I8B&
  crmSourceType=YOUR_CRM_SOURCE_TYPE&
  crmInstanceType=YOUR_CRM_INSTANCE_TYPE&
  crmType=account&
  modules=TopCard2&
  version=2.1&
  isInlineMode=false&
  sat=Aj2AKAv"
  width="300"
  height="265"
  frameborder="0"
  type="text/html">
</iframe>

Query Parameters

Note

If no module is specified or the module query parameter is missing, then all modules will be rendered. This will allow any newly released modules to be rendered automatically for the end user.

Lead Query Parameters

Parameters Required? Description
crmSourceType Required This must be set to the value provided by LinkedIn. If you're unsure how to set this value, please contact your LinkedIn representative.
apiKey Required The provisioned child application's API key, also called Client ID.
firstName Optional Only valid for leads/member profiles. Used to find the most relevant person based on first name.
lastName Optional Only valid for leads/member profiles. Used to find the most relevant person based on last name.
email Optional Only valid for leads/member profiles. Used to find the most relevant person based on email.
title Optional Only valid for leads/member profiles. Used to find the most relevant person based on job title.
companyName Optional Valid for leads/member profiles. Used to find the most relevant person at a company based on the company name.
crmRecordId Required The record ID of the external record corresponding to the profile being requested. This value should be unique, under 28 characters (only alphanumeric and hyphen characters accepted), and is usually the unique identifier for this contact or lead record in the external system.
crmOrgId Required The organization ID, customer ID, or tenant ID for the instance utilizing the iframe. This value should be unique, under 28 characters (only alphanumeric and hyphen characters accepted), and is usually the unique identifier for the organization or tenant in the external system.
crmType Optional The type of the crm record, either contact or lead
modules Optional A comma-separated list representing the components to load. For profiles, valid values are:
  • TopCard2
  • Messaging
  • Connect
  • Icebreakers
  • RecentActivity
  • Highlights
  • GetIntroduced
  • RelatedLeads
Note: If no module is specified or the parameter is missing, then all the modules available will be rendered.
isInlineMode Optional Boolean value that identifies whether or not to render component in Inline Mode. If using Inline Mode, pass only one module. Valid values:
  • true
  • false (Default)
version Optional Only applicable when embedding via HTML iframe. Not required, but should always be passed to maintain your desired experience. Valid values:
  • 2.1
appVersion Optional Indicates the installed application version from the integrating CRM (Currently used by Salesforce).
sat Optional If a Sales Access Token is passed in this parameter, it will be used to authenticate the Sales Navigator user and create a session in their client. If using this feature, version must be set to 2.1 or higher.

Company Query Parameters

Parameters Required? Description
crmSourceType Required This must be set to the value provided by LinkedIn. If you're unsure how to set this value, please contact your LinkedIn representative.
crmInstanceType Required This must be set to the value of either DEV or SANDBOX or PRODUCTION based on your CRM Instance type. If you're unsure how to set this value, please contact your LinkedIn representative.
apiKey Required The provisioned child application's API key, also called Client ID.
name Optional Only valid for companies/accounts. Used to find the most relevant company based on the company name.
website Optional Only valid for companies/accounts. Used to find the most relevant company based on the company website.
industry Optional Only valid for companies/accounts. Used to find the most relevant company based on the industry.
location Optional Only valid for companies/accounts. Used to find the most relevant company based on the location.
crmRecordId Required The record ID of the external record corresponding to the company being requested. This value should be unique, under 28 characters (only alphanumeric and hyphen characters accepted), and is usually the unique identifier for this account record in the external system.
crmOrgId Required The organization ID, customer ID, or tenant ID for the instance utilizing the iframe. This value should be unique, under 28 characters (only alphanumeric and hyphen characters accepted), and is usually the unique identifier for the organization or tenant in the external system.
crmType Optional The type of the crm record, always account for company-matching
isExpandEnabled Optional Boolean value that identifies whether or not to show the expand button for the Relationship Map component. Valid values:
  • true
  • false (Default)
If this is set to True, kindly refer to this section to handle the Expand/Collapse button.
modules Optional A comma-separated list representing the company profile card and the tabs in the iframe. For company-matching, valid values are:
  • TopCard
  • Connections
  • News
  • RecommendedLeads (Available only for the Advanced users)
  • FindPeople (Replacement for Recommended Leads module and available only to the Advanced Plus users)
  • Maps (Available only to the Advanced Plus users)
Note: If no module is specified or the parameter is missing, then all the modules of the selected account will be rendered.
isInlineMode Optional Supported since version 2.0.0. Boolean value that identifies whether or not to render component in Inline Mode. If using Inline Mode, pass only one module. Valid values:
  • true
  • false (Default)
version Optional Only applicable when embedding via HTML iframe. Not required, but should always be passed to maintain your desired experience. Valid values:
  • 2.1
appVersion Optional Indicates the installed application version from the integrating CRM (Currently used by Salesforce).
sat Required If a Sales Access Token is passed in this parameter, it will be used to authenticate the Sales Navigator user and create a session in their client. If using this feature, version must be set to 2.1 or higher.

Handling the Expand/Collapse button

The Expand button will be present in the “Relationship Map” widget iframe UI and button will be handled using the Lightning component full screen modal.

The expand button needs to be handled at the widget end. You need to handle the "expand" message from the widget iframe. The expand event will be passed to the parent window by window.postMessage() method. To listen to the event, you can use a standard event listener for a message event like below and obtain event data from data object:

/** Partner app needs to listen to the "expand" message from the widget iframe **/

window.addEventListener("message", function(event) {
  var origin = event.origin; // "https://www.linkedin.com"
  var message = event.data; // "{"actionTaken":"Expand"}"
  if (origin === "https://www.linkedin.com" 
      && message.actionTaken === "Expand")  {
    // Implement expand handling, e.g tweaking the CSS of widget to occupy the entire screen or opening partner's full screen modal with iFrame embedded
  }
});

Likewise, you need to send the “collapse” event back to us to notify the close event as follows:

/** Partner app needs to send a postMessage to communicate the close event to the iframe **/

const message = { actionTaken: “collapse”};
const targetOrigin = 'https://linkedin.com';
window.postMessage(message, targetOrigin);