1. Create a simple Quick Action component.
HTML:
<template>
</template>
JavaScript:
import { LightningElement, api } from 'lwc';
import { NavigationMixin } from 'lightning/navigation';
export default class SampleQuickAction extends NavigationMixin( LightningElement ) {
@api recordId;
@api invoke() {
this[NavigationMixin.Navigate]( {
type: 'standard__navItemPage',
attributes: {
apiName: 'Sample_Tab'
},
state: {
c__recId: this.recordId
}
} );
}
}
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__RecordAction</target>
<target>lightning__RecordPage</target>
</targets>
<targetConfigs>
<targetConfig targets="lightning__RecordAction">
<actionType>Action</actionType>
</targetConfig>
</targetConfigs>
</LightningComponentBundle>
2. Create a Quick Action using the above component.
data:image/s3,"s3://crabby-images/de0c4/de0c4e1814169bc2aa99bbbb336db53788473d32" alt=""
3. Add the above Quick Action to the page layout.
4. Create a Lightning Web Component(LWC) for a Tab.
HTML:
<template>
<lightning-card>
<template if:true={recordBool}>
{recId}
</template>
<template if:false={recordBool}>
Record Id is not passed
</template>
</lightning-card>
</template>
JavaScript:
import { LightningElement, wire } from 'lwc';
import { CurrentPageReference } from 'lightning/navigation';
export default class SampleTab extends LightningElement {
recordBool = false;
recId;
currentPageReference;
@wire( CurrentPageReference )
setCurrentPageReference( currentPageReference ) {
this.currentPageReference = currentPageReference;
let tempRecId = this.currentPageReference.state.c__recId;
console.log( 'Rec Id is ' + tempRecId );
if ( tempRecId ) {
this.recordBool = true;
this.recId = tempRecId;
} else {
this.recordBool = false;
this.recId = undefined;
}
}
}
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__Tab</target>
</targets>
</LightningComponentBundle>
5. Create a tab for the above component.
data:image/s3,"s3://crabby-images/e5989/e5989604d37fcf87fdc5f68b87c4871a3a8a5dac" alt=""
6. Add the above Tab to your App Navigation Items.
Output:
data:image/s3,"s3://crabby-images/381a7/381a7ab7d8bdb13f5e1afb26cb2e106bb922480b" alt=""
Navigated from Account:
data:image/s3,"s3://crabby-images/faf19/faf1971cc8f47e3b0ce5ad4551ce993d2883f452" alt=""
Clicking Sample Tab after navigating from Account(This removes the query parameter):
data:image/s3,"s3://crabby-images/d37a6/d37a6edf1c1b563db74e645d51dec71d5a7ce7ad" alt=""