summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorThomas Tanghus <thomas@tanghus.net>2013-05-04 12:27:24 -0700
committerThomas Tanghus <thomas@tanghus.net>2013-05-04 12:27:24 -0700
commit83db2c83ad2bfac9b1c49810f04b0f0788045062 (patch)
treebd5ba1a6e2a13b48688ab955ad9f5ba7dca50ec3 /core
parenta876240b32ec4322d9e01cb6111bb4b5ee3374b7 (diff)
parent048569754aec39b0e58232107e8108fed70bf7e8 (diff)
downloadnextcloud-server-83db2c83ad2bfac9b1c49810f04b0f0788045062.tar.gz
nextcloud-server-83db2c83ad2bfac9b1c49810f04b0f0788045062.zip
Merge pull request #3177 from owncloud/outerHTML_compatibility
Add compatibility function for outerHTML
Diffstat (limited to 'core')
-rw-r--r--core/js/compatibility.js16
-rw-r--r--core/js/octemplate.js2
2 files changed, 16 insertions, 2 deletions
diff --git a/core/js/compatibility.js b/core/js/compatibility.js
index cc37949409d..b690803ca77 100644
--- a/core/js/compatibility.js
+++ b/core/js/compatibility.js
@@ -133,4 +133,18 @@ if(!String.prototype.trim) {
String.prototype.trim = function () {
return this.replace(/^\s+|\s+$/g,'');
};
-} \ No newline at end of file
+}
+
+// Older Firefoxes doesn't support outerHTML
+// From http://stackoverflow.com/questions/1700870/how-do-i-do-outerhtml-in-firefox#answer-3819589
+function outerHTML(node){
+ // In newer browsers use the internal property otherwise build a wrapper.
+ return node.outerHTML || (
+ function(n){
+ var div = document.createElement('div'), h;
+ div.appendChild( n.cloneNode(true) );
+ h = div.innerHTML;
+ div = null;
+ return h;
+ })(node);
+}
diff --git a/core/js/octemplate.js b/core/js/octemplate.js
index a5d56852a57..e032506c0b1 100644
--- a/core/js/octemplate.js
+++ b/core/js/octemplate.js
@@ -72,7 +72,7 @@
},
// From stackoverflow.com/questions/1408289/best-way-to-do-variable-interpolation-in-javascript
_build: function(o){
- var data = this.elem.attr('type') === 'text/template' ? this.elem.html() : this.elem.get(0).outerHTML;
+ var data = this.elem.attr('type') === 'text/template' ? this.elem.html() : outerHTML(this.elem.get(0));
try {
return data.replace(/{([^{}]*)}/g,
function (a, b) {