When the Articles are detached from the Salesforce Chat Transcripts, the LinkedArticle Object/Entity records will be deleted. To detach Articles from the Salesforce Cases, we have to remove the relevant records from the CaseArticle Object/Entity.
In the following Sample Flow:
- We first check whether the Article is attached to the Chat Transcript.
- Using Get Records Element to fetch the Chat Transcript records. We need Case Id. So, we are fetching it.
- Using Get Records Element to fetch the Case Articles.
- Using Decision Element, we are checking whether the Case Articles are fetched.
- If the Case Articles are found, then using Delete Record Elements, we are deleting the Case Articles.
Sample Flow:
data:image/s3,"s3://crabby-images/89a03/89a03a2f84d7fe31f6ece58d4b70eba64c2e4c6c" alt=""
Start Element Configuration:
data:image/s3,"s3://crabby-images/32e32/32e325014d93b011a645c75324c9dc76475101e7" alt=""
Fetch Chat Transcript:
data:image/s3,"s3://crabby-images/8a12a/8a12a8c6dd75123c0a0b18513579d89644d3e38c" alt=""
Fetch Case Articles:
data:image/s3,"s3://crabby-images/abd95/abd955066ce3c123d123788641f78e8b69c46a01" alt=""
Case Articles Check:
data:image/s3,"s3://crabby-images/d208a/d208af62c65a1c4ce9ec0f6923e8cb3fb86e7b23" alt=""
Delete Case Articles:
data:image/s3,"s3://crabby-images/9a841/9a8412d317a4a8d2d5bc2e880c01c4b455f0a300" alt=""
If you would like to use Apex Trigger, then you can check the following Apex Trigger.
In the following sample Apex Trigger, we are using after delete event LinkedArticle object/entity.
- We are checking whether the LinkedEntityId is Chat Transcript Id.
- We are storing the Knowledge Article Ids and the Chat Transcript Ids.
- We are fetching the Chat Transcripts to get the related Case Ids.
- We are fetching the Case Articles using the Case Ids and the Knowledge Article Ids.
- If Case Articles are present, then they are deleted detach articles detached from the Chat Transcript from the Case in Salesforce.
Sample Apex Trigger:
trigger LinkedArticleTrigger on LinkedArticle ( after delete ) {
Set < Id > setKAIds = new Set < Id >();
Set < Id > setChatIds = new Set < Id >();
for ( LinkedArticle objLA : trigger.old ) {
String strLinkedEntityId = objLA.LinkedEntityId;
if ( strLinkedEntityId.startsWith( '570' ) ) {
setKAIds.add( objLA.KnowledgeArticleId );
setChatIds.add( objLA.LinkedEntityId );
}
}
if ( setChatIds.size() > 0 ) {
Set < Id > setCaseIds = new Set < Id >();
for (
LiveChatTranscript objCT : [
SELECT CaseId
FROM LiveChatTranscript
WHERE Id IN: setChatIds
]
) {
setCaseIds.add( objCT.CaseId );
}
if ( setCaseIds.size() > 0 ) {
List < CaseArticle > listCAs = [
SELECT Id
FROM CaseArticle
WHERE CaseId IN:setCaseIds
AND KnowledgeArticleId IN: setKAIds
];
if ( listCAs.size() > 0 ) {
delete listCAs;
}
}
}
}
SOQL for LinkedArticle:
SELECT Id, LinkedEntityId
FROM LinkedArticle
SOQL for CaseArticle:
SELECT Id, CaseId
FROM CaseArticle
If you have an use case to attach articles attached to the Chat Transcript to Case in Salesforce, please check the following: