-
Notifications
You must be signed in to change notification settings - Fork 35
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Zendesk turbolinks script doesn't work #52
Comments
@andrewkouri I had with the same problem, when clicked in any link the zendesk stop of work, 'cause in my case i'm using zopim chat. To fix my problem, I added 2 new lines. After/before of these lines: window.zEmbed = window.zE = undefined
$('head iframe[src="javascript:false"]').remove() I added: $('[__jx__id], embed#__zopnetworkswf').remove()
window.$zopim = null |
@leonardostefani that did for me, thanks! But I've set Now my widget function looks like this: // reference: http://reed.github.io/turbolinks-compatibility/zendesk_web_widget.html
function zendeskWebWidget(userName, userEmail, enableHelpCenter, enableChat){
var zendesk_host = 'myhostname.zendesk.com';
window.zEmbed = window.zE = undefined;
$('head iframe[src="javascript:false"]').remove();
// reference: https://github.com/reed/turbolinks-compatibility/issues/52
$('[__jx__id], embed#__zopnetworkswf').remove()
window.$zopim = undefined;
(function(url, host) {
var queue = [],
dom,
doc,
where,
iframe = document.createElement('iframe'),
iWin,
iDoc;
window.zEmbed = function() {
queue.push(arguments);
};
window.zE = window.zE || window.zEmbed;
window.zESettings = {
webWidget: {
helpCenter: {
suppress: !enableHelpCenter
},
chat: {
suppress: !enableChat
}
}
};
iframe.src = 'javascript:false';
iframe.title = ''; iframe.role='presentation'; // a11y
(iframe.frameElement || iframe).style.cssText = 'display: none';
where = document.getElementsByTagName('script');
where = where[where.length - 1];
where.parentNode.insertBefore(iframe, where);
iWin = iframe.contentWindow;
iDoc = iWin.document;
try {
doc = iDoc;
} catch(e) {
dom = document.domain;
iframe.src='javascript:var d=document.open();d.domain="'+dom+'";void(0);';
doc = iDoc;
}
doc.open()._l = function() {
var js = this.createElement('script');
if (dom) this.domain = dom;
js.id = 'js-iframe-async';
js.src = url;
this.t = +new Date();
this.zendeskHost = zendesk_host;
this.zEQueue = queue;
this.body.appendChild(js);
};
doc.write('<body onload="document._l();">');
doc.close();
}('//assets.zendesk.com/embeddable_framework/main.js', "myhostname"));
if(userName != ''){
zE( function () {
zE.identify({name: userName, email: userEmail});
});
}
} And on the page header I have: $(document).on("turbolinks:load", function() {
var userName = 'username'; // fill it your way
var userEmail = 'userEmail';
var enableHelpCenter = false;
var enableChat = true;
zendeskWebWidget(userName, userEmail, enableHelpCenter, enableChat);
}); If anyone sees a better way to do this, please help me improve it! Thank you! |
Made trick! awesome. |
Its strange how setting |
@MauricioMoraes That worked perfectly. Thanks so much! |
hey, I was wondering if this still works @MauricioMoraes |
@Ghostavio we've ditched zendesk/zopim a year ago. So I have no idea if this workaround is still working. But my gut tells me that it should, because those widget inclusion scripts change very little over time (too much caching and compatibility problems to change it), and the main script is loaded from the server. So there is little risk of you wasting your time trying it out. |
Turbolinks does not work with the zendesk script contributed. When you navigate away from the current page by clicking on a link, the zendesk widget does not persist between pages.
The text was updated successfully, but these errors were encountered: