Files
edx-platform/cms/static/js/utils/handle_iframe_binding.js
2014-01-16 13:33:54 +05:00

67 lines
2.7 KiB
JavaScript

define(["jquery"], function($) {
var iframeBinding = function (e) {
var target_element = null;
if (typeof(e) === "undefined") {
target_element = $("iframe, embed");
} else {
if (typeof(e.nodeName) !== 'undefined') {
target_element = $(e).find("iframe, embed");
} else {
target_element = e.$("iframe, embed");
}
}
modifyTagContent(target_element);
};
var modifyTagContent = function (target_element) {
target_element.each(function() {
if ($(this).prop('tagName') === 'IFRAME') {
var ifr_source = $(this).attr('src');
// Modify iframe src only if it is not empty
if (ifr_source) {
var wmode = "wmode=transparent";
if (ifr_source.indexOf('?') !== -1) {
var getQString = ifr_source.split('?');
if (getQString[1].search('wmode=transparent') === -1) {
var oldString = getQString[1];
var newString = getQString[0];
$(this).attr('src', newString + '?' + wmode + '&' + oldString);
}
}
else {
$(this).attr('src', ifr_source + '?' + wmode);
}
}
}
else {
$(this).attr('wmode', 'transparent');
}
});
};
// Modify iframe/embed tags in provided html string
// Use this method when provided data is just html sting not dom element
// This method will only modify iframe (add wmode=transparent in url querystring) and embed (add wmode=transparent as attribute)
// tags in html string so both tags will attach to dom and don't create z-index problem for other popups
// Note: embed tags should be modified before rendering as they are static objects as compared to iframes
// Note: this method can modify unintended html (invalid tags) while converting to dom object
var iframeBindingHtml = function (html_string) {
if (html_string){
var target_element = null;
var temp_content = document.createElement('div');
$(temp_content).html(html_string);
target_element = $(temp_content).find("iframe, embed");
if (target_element.length > 0){
modifyTagContent(target_element);
html_string = $(temp_content).html();
}
}
return html_string;
};
return {
iframeBinding: iframeBinding,
iframeBindingHtml: iframeBindingHtml
};
});