data:image/s3,"s3://crabby-images/7821e/7821e28a54357aa89932a83068545b03e956358e" alt=""
role=”outputOnly” should set in the property tag for the targetConfig targets=”lightning__FlowScreen” tag to pass data from Salesforce Lightning Web Component to Flow.
Sample Lightning Web Component:
HTML:
<template>
<lightning-card>
<lightning-datatable
key-field="Id"
data={listAccounts}
columns={columns}
show-row-number-column
onrowselection={handleSelected}>
</lightning-datatable>
</lightning-card>
</template>
JavaScript:
import { LightningElement, api } from 'lwc';
export default class AccountDataTable extends LightningElement {
@api listAccounts;
@api selectedAccounts;
columns = [
{ label: 'Id', fieldName: 'Id' },
{ label: 'Name', fieldName: 'Name' },
{ label: 'Industry', fieldName: 'Industry' },
{ label: 'Account Number', fieldName: 'AccountNumber' },
{ label: 'Type', fieldName: 'Type' }
];
handleSelected( event ) {
this.selectedAccounts = event.detail.selectedRows;
console.log(
'Selected Accounts are',
JSON.stringify(
this.selectedAccounts
)
);
}
}
js-meta.xml:
<?xml version="1.0" encoding="UTF-8"?>
<LightningComponentBundle xmlns="http://soap.sforce.com/2006/04/metadata">
<apiVersion>59.0</apiVersion>
<isExposed>true</isExposed>
<targets>
<target>lightning__FlowScreen</target>
</targets>
<targetConfigs>
<targetConfig targets="lightning__FlowScreen">
<property
name="listAccounts"
label="Account List"
type="@salesforce/schema/Account[]"
role="inputOnly"
/>
<property
name="selectedAccounts"
label="Selected Account List"
type="@salesforce/schema/Account[]"
role="outputOnly"
/>
</targetConfig>
</targetConfigs>
</LightningComponentBundle>
Sample Flow:
data:image/s3,"s3://crabby-images/a3df7/a3df7fbca51b7facbac8cd9b9e918bdae2ab1c2c" alt=""
Account Detail Configuration:
Account Name will be captured from the user.
data:image/s3,"s3://crabby-images/a5c84/a5c84ad18235dfa2a737b422f74453f73e5dc867" alt=""
Search Accounts Configuration:
data:image/s3,"s3://crabby-images/aa0d2/aa0d2ab2fbc6c0fb0539df55aaf54abad51cdb23" alt=""
data:image/s3,"s3://crabby-images/d6488/d6488c5f48e28b27324b786289b6a91c1c55d717" alt=""
Matching Account Configuration:
data:image/s3,"s3://crabby-images/1b7a3/1b7a33fbb4d0b42a556d28e7f8249a0e5dd0032d" alt=""
Collection Choice Set Variable:
selectedAccounts is the Output Variable from the Salesforce Lightning Web Component. DisplayAccounts is the API name of the Lightning Web Component added to the Screen Element.
data:image/s3,"s3://crabby-images/1a75b/1a75be61d88857d3e189ee4a18f62fbe71d31a42" alt=""
Select Account Configuration:
data:image/s3,"s3://crabby-images/a6c50/a6c50cdeb04f06c6abf0cd0cebe0f4665ea05322" alt=""
Output:
data:image/s3,"s3://crabby-images/9ad44/9ad44b73d0264136e9f2f6b8b8a5b1013a7eeb92" alt=""
data:image/s3,"s3://crabby-images/a4d72/a4d7233f3d7b58590ef60167f83b631956036fed" alt=""
data:image/s3,"s3://crabby-images/f0ca1/f0ca1d01f14889d5da33156e365deae084122cf6" alt=""