2020-02-13 17:05:48 +00:00
|
|
|
const params = window.location.search.substring(1).split('&');
|
|
|
|
let lockOrigin;
|
|
|
|
for (let i = 0; i < params.length; ++i) {
|
|
|
|
const parts = params[i].split('=');
|
2020-02-13 16:58:27 +00:00
|
|
|
if (parts[0] === 'origin') lockOrigin = decodeURIComponent(parts[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
function remoteRender(event) {
|
|
|
|
const data = event.data;
|
|
|
|
|
|
|
|
const img = document.createElement("img");
|
|
|
|
img.id = "img";
|
|
|
|
img.src = data.imgSrc;
|
|
|
|
img.style = data.imgStyle;
|
|
|
|
|
|
|
|
const a = document.createElement("a");
|
|
|
|
a.id = "a";
|
2020-02-23 22:14:29 +00:00
|
|
|
a.rel = "noreferrer noopener";
|
2020-02-13 16:58:27 +00:00
|
|
|
a.download = data.download;
|
|
|
|
a.style = data.style;
|
|
|
|
a.style.fontFamily = "Arial, Helvetica, Sans-Serif";
|
|
|
|
a.href = window.URL.createObjectURL(data.blob);
|
|
|
|
a.appendChild(img);
|
|
|
|
a.appendChild(document.createTextNode(data.textContent));
|
|
|
|
|
|
|
|
const body = document.body;
|
|
|
|
// Don't display scrollbars if the link takes more than one line to display.
|
|
|
|
body.style = "margin: 0px; overflow: hidden";
|
|
|
|
body.appendChild(a);
|
2020-03-03 13:23:33 +00:00
|
|
|
|
|
|
|
if (event.data.auto) {
|
|
|
|
a.click(); // try to trigger download automatically
|
|
|
|
}
|
2020-02-13 16:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function remoteSetTint(event) {
|
|
|
|
const data = event.data;
|
|
|
|
|
|
|
|
const img = document.getElementById("img");
|
|
|
|
img.src = data.imgSrc;
|
|
|
|
img.style = data.imgStyle;
|
|
|
|
|
|
|
|
const a = document.getElementById("a");
|
|
|
|
a.style = data.style;
|
|
|
|
}
|
|
|
|
|
|
|
|
window.onmessage = function(e) {
|
2020-02-19 12:44:46 +00:00
|
|
|
if (e.origin === lockOrigin) {
|
2020-02-13 16:58:27 +00:00
|
|
|
if (e.data.blob) remoteRender(e);
|
|
|
|
else remoteSetTint(e);
|
|
|
|
}
|
|
|
|
};
|