我刚刚开始使用dialogflow和kommunicate.io创建一个机器人。因此,我创建了一个简单的机器人并将其与kommunicate集成,最后将kommunicatesettings脚本复制到了HTML页面中。我可以从机器人那里得到简单的回应。但是现在我想为每个HTML页面设置不同的欢迎消息。那么可以使用kommunicatesettings完成此操作吗?我尝试过:
var kommunicateSettings = {"appId":"7519ee060abee2b532e8565aa0527ae","popupWidget":true,"automaticChatOpenOnNavigation":true,
"appSettings": {
"chatWidget": {
"popup": true
},
"chatPopupMessage": [{
"message": "Wanna ask something related to "+document.title+ "?",
"delay": 3000
}],
"text": {
"text": ["My welcome message!"]
}
}
};
var s = document.createElement("script"); s.type = "text/javascript"; s.async = true;
s.src = "https://widget.kommunicate.io/v2/kommunicate.app";
var h = document.getElementsByTagName("head")[0]; h.appendChild(s);
window.kommunicate = m; m._globals = kommunicateSettings;
})(document, window.kommunicate || {});
设置中的“文字”。但是它无能为力。
我只想在欢迎消息中显示文档标题。因此,如果某些用于实现的nodejs代码可以做到这一点,那就没问题了(document.title和window.location在实现代码中不起作用)。
答案 0 :(得分:2)
您可以启用和自定义DialogFlow中的default welcome intent
,当对话通过机器人路由时,Kommunicate会触发var chatContext = {
"key1":"value1",
"key2":"value2"
}
Kommunicate.updateSettings({"KM_CHAT_CONTEXT":chatContext})
(例如,在页面重新加载和Kommunicate插件的初始化时)。
我不确定是否可以为每个页面自定义欢迎页面,至少不容易。
一种尝试的方法是将一些自定义数据传递给DialogFlow
"originalDetectIntentRequest": {
"payload": {
"key1": "value1",
"key2": "value2"
}
}
然后将其传递到Webhook
SELECT COLUMN1, COLUMN2, COLUMN3, COLUMN4 from <TABLE>
我认为它最终可以用于个性化您的欢迎信息。
答案 1 :(得分:2)
当新的对话开始并通过Dialogflow机器人进行路由时,Kommunicate会触发在Dialogflow控制台中配置的Default Welcome Intent
。但是,您可以自定义欢迎消息并为对话动态设置其他欢迎消息。您必须在Dialogflow控制台上创建事件,并在customWelcomeEvent
参数中传递事件。以下是完整的脚本:
(function (d, m) {
var kommunicateSettings = {
"appId": "your-app-Id",
onInit: function (status, data) {
if (status == "success") {
Kommunicate.updateSettings({ "customWelcomeEvent": "welcome_event_for_home_page" });
}
}
};
var s = document.createElement("script"); s.type = "text/javascript"; s.async = true;
s.src = "https://widget.kommunicate.io/v2/kommunicate.app";
var h = document.getElementsByTagName("head")[0]; h.appendChild(s);
window.kommunicate = m; m._globals = kommunicateSettings;
})(document, window.kommunicate || {});
当网站上发生某些事件时,您可以动态更新此设置。 此设置将应用于更新后开始的所有新对话,即,更新设置后开始的对话将触发新的欢迎事件。
此外,此设置还可用于在网站的不同页面上显示不同的欢迎消息。
我希望它会有所帮助。