In Salesforce, to pass parameter from the Flow to the Lightning Web Component, we have to use targetConfig targets=”lightning__FlowScreen”.
Please check the following example for your reference. Account Id value is passed from the Screen Flow to the Lightning Web Component. In the Lightning Web Component, lightning-record-view-form is used to display the Account Record.
Sample Code:
HTML:
<template>
<lightning-card>
<lightning-record-view-form object-api-name="Account" record-id={accountId}>
<lightning-output-field field-name="Name"></lightning-output-field>
<lightning-output-field field-name="AccountNumber"></lightning-output-field>
<lightning-output-field field-name="Type"></lightning-output-field>
<lightning-output-field field-name="Industry"></lightning-output-field>
<lightning-output-field field-name="Website"></lightning-output-field>
</lightning-record-view-form>
</lightning-card>
</template>
JavaScript:
import { api, LightningElement } from 'lwc';
export default class FlowComponent extends LightningElement {
@api accountId;
}
js-meta.xml:
<?xml version="1.0" encoding="UTF-8"?>
<LightningComponentBundle xmlns="http://soap.sforce.com/2006/04/metadata">
<apiVersion>52.0</apiVersion>
<isExposed>true</isExposed>
<targets>
<target>lightning__FlowScreen</target>
</targets>
<targetConfigs>
<targetConfig targets="lightning__FlowScreen">
<property name="accountId" label="Account Id" type="String" role="inputOnly"/>
</targetConfig>
</targetConfigs>
</LightningComponentBundle>
Sample Flow:
data:image/s3,"s3://crabby-images/fbe84/fbe84713328708091a81a717e110c22f5e1fa023" alt=""
data:image/s3,"s3://crabby-images/93190/93190b72287b1e00ce1b03f8a67c1228b6a54fc4" alt=""
data:image/s3,"s3://crabby-images/d3394/d3394c1644becbfbb568f854e05423ef7fa3fc4a" alt=""
Output:
data:image/s3,"s3://crabby-images/1c210/1c210e17aa6fd9d7d222a52f7c1c0b08913b3d69" alt=""
data:image/s3,"s3://crabby-images/b32cc/b32cc36062c70a8486f9023dce1e9b66be848072" alt=""