website/assets/script/compatibility.js
2022-11-03 21:05:54 +01:00

84 lines
2.7 KiB
JavaScript

if (!document.getElementsByClassName) {
document.getElementsByClassName = function(className) {
if (document.querySelectorAll)
return document.querySelectorAll("." + className);
var results = [];
for (var i = 0; i < document.all.length; i++) {
if (new RegExp("\\b" + className + "\\b").test(document.all[i].className))
results.push(document.all[i]);
}
return results;
}
}
if (!document.querySelector) {
var style = document.createStyleSheet();
// https://stackoverflow.com/a/53554212
document.querySelector = function(query) {
style.addRule(query, "foo:bar");
for (var i = 0; i < document.all.length; i++) {
if (document.all[i].currentStyle.foo === "bar")
return document.all[i];
}
style.removeRule(0);
}
}
if (!window.addEventListener) {
window.addEventListener = function(event, callback) {
window.attachEvent("on" + event, callback);
}
}
if (!document.head) {
document.head = document.getElementsByTagName("head")[0];
}
if (!window.HTMLPictureElement) {
document.createElement("picture");
}
function toArray(iter) {
var arr = [];
for (var i = 0; i < iter.length; i++) arr.push(iter[i]);
return arr;
}
// Fix images not updating on Opera 12.1 - 12.16 (earlier versions still broken)
// https://stackoverflow.com/a/71828058/8618686
if(window.opera && Object.defineProperty) {
/* if browser is opera presto, updating image elements' sources will not upload the DOM visual.
So we need to do some hacking. Only thing that works is to remove and reAppend the relevant node... */
Object.defineProperty(HTMLImageElement.prototype, "src", {
enumerable: true,
configurable: true,
get: function() {
return this.getAttribute("src");
},
set: function(newSrc)
{
/*max-size confinement is required for presto if parent is display flex. Image will go out of its available size otherwise*/
this.style.maxHeight = this.style.height;
this.style.maxWidth = this.style.width;
this.setAttribute("src", newSrc);
/*we have to put this node back to exactly where we rip it from*/
var parent = this.parentNode;
if(this.nextElementSibling != null)
{
var reference = this.nextElementSibling;
parent.removeChild(this);
reference.insertAdjacentElement("beforebegin", this);
}
else if (parent)
{
parent.removeChild(this);
parent.appendChild(this);
}
}
});
}