On this page
Integrate RWC into the SalesForce Canvas App
The RWC can be embedded into the SalesForce system as a third-party application and can be used in the VisualForce or Lightning templates.
Instruction
- Sign in to the developer console.
- Go to the Setup view.
data:image/s3,"s3://crabby-images/81eb3/81eb3748084285b44ebe05bd84e697cb02ebb380" alt=""
- In the Search field type "app manager" and select the suggested setting.
data:image/s3,"s3://crabby-images/0ad77/0ad773a36b2b81f15a3a4190b06974685b1616e2" alt=""
- To add a third-party app, click New connected app on the right.
data:image/s3,"s3://crabby-images/812e8/812e8943e66ecb3278734873e9a5b666f47a53d1" alt=""
- Fill in all required fields adding the chat URL here:
data:image/s3,"s3://crabby-images/8399a/8399a0379a19bfa5c9f91d8c30b2916ded5a232e" alt=""
- Now you can use RWC as a Canvas App in VisualForce or Lightning templates.
data:image/s3,"s3://crabby-images/af254/af25440a005c0f099de3252bb702ab31b3fc66fd" alt=""
How to share events between RWC and SalesForce
WARNING
To receive events on the Canvas App, the application has to be authorized. Find more about authorization at SalesForce canvas developer guide.
To send events from SalesForce to the RWC app, add Canvas SDK to the VisualForce app:
Publish events using the Sfdc helper:
html
<apex:page >
<script type="text/javascript" src="/canvas/sdk/js/31.0/controller.js"></script>
<script type="text/javascript" src="/soap/ajax/31.0/connection.js">
<button id="closeBtn">click</button>
<apex:canvasApp developerName="YOUR_APP_NAME_HERE" height="400px" width="300px"/>
<script>
var ctxlink = document.querySelector('#closeBtn')
ctxlink.onclick=function() {
Sfdc.canvas.controller.publish({
name : 'EVENT_NAME_HERE',
payload : {
myData: 'Some payload'
}
});
}
</script>
</apex:page>
<apex:page >
<script type="text/javascript" src="/canvas/sdk/js/31.0/controller.js"></script>
<script type="text/javascript" src="/soap/ajax/31.0/connection.js">
<button id="closeBtn">click</button>
<apex:canvasApp developerName="YOUR_APP_NAME_HERE" height="400px" width="300px"/>
<script>
var ctxlink = document.querySelector('#closeBtn')
ctxlink.onclick=function() {
Sfdc.canvas.controller.publish({
name : 'EVENT_NAME_HERE',
payload : {
myData: 'Some payload'
}
});
}
</script>
</apex:page>
- To create a subscription to the events, it is necessary to use SalesForce CanvasSdk in the RWC. To create the subscription:
a. Click on the Wait for Chat (RWC) Step of your Flow
b. Scroll down to and expand the Advanced Settings section
c. Enable the Extend page head by custom template
d. Add the following code to the HTML template field
js
<script type="text/javascript" src="https://home-6f2-dev-ed.my.salesforce.com/canvas/sdk/js/31.0/canvas-all.js" onload="onCanvasSdkLoad()"></script>
<script>
const onCanvasSdkLoad = function () {
const client = window.Sfdc.canvas.oauth.client();
// auth required. token below is initial token from App Manager
client.oauthToken = 'AUTH_TOKEN_HERE'
window.Sfdc.canvas.client.subscribe(client, {
name: 'EVENT_NAME_HERE',
onData: function() {
// some actions
}
})
}
</script>
<script type="text/javascript" src="https://home-6f2-dev-ed.my.salesforce.com/canvas/sdk/js/31.0/canvas-all.js" onload="onCanvasSdkLoad()"></script>
<script>
const onCanvasSdkLoad = function () {
const client = window.Sfdc.canvas.oauth.client();
// auth required. token below is initial token from App Manager
client.oauthToken = 'AUTH_TOKEN_HERE'
window.Sfdc.canvas.client.subscribe(client, {
name: 'EVENT_NAME_HERE',
onData: function() {
// some actions
}
})
}
</script>
e. Save & Activate the Flow