// JavaScript
// Panel creator
"use strict";
function createPanelFrame (sId, sTitle) {
try {
let xPanel = createNode("div", {id: sId, className: "grammalecte_panel"});
let xBar = createNode("div", {className: "grammalecte_title_bar"});
xBar.appendChild(createCloseButton(xPanel));
let xTitle = createNode("div", {className: "grammalecte_title"});
xTitle.appendChild(createLogo());
xTitle.appendChild(createNode("div", {className: "grammalecte_label", textContent: "Grammalecte · " + sTitle}));
xBar.appendChild(xTitle);
xPanel.appendChild(xBar);
//xPanel.appendChild(createNode("div", {className: "grammalecte_empty_space_under_title_bar"}));
xPanel.appendChild(createNode("div", {id: sId+"_content", className: "grammalecte_panel_content"}));
return xPanel;
}
catch (e) {
showError(e);
}
}
function createCloseButton (xParentNode) {
let xButton = document.createElement("div");
xButton.className = "grammalecte_close_button";
xButton.textContent = "×";
xButton.onclick = function () {
xParentNode.style.display = "none";
}
return xButton;
}
/*
Common functions
*/
function createNode (sType, oAttr) {
try {
let xNode = document.createElement(sType);
Object.assign(xNode, oAttr);
return xNode;
}
catch (e) {
showError(e);
}
}
function createCheckbox (sId, bDefault, sClass="") {
let xInput = document.createElement("input");
xInput.type = "checkbox";
xInput.id = sId;
xInput.className = sClass;
xInput.dataset.default = bDefault;
return xInput;
}
function createLabel (sForId, sLabel, sClass="") {
let xLabel = document.createElement("label");
xLabel.setAttribute("for", sForId);
xLabel.textContent = sLabel;
return xLabel;
}
function createLogo () {
let xImg = document.createElement("img");
xImg.src = "";
return xImg;
}
function loadImage (sContainerClass, sImagePath) {
let xRequest = new XMLHttpRequest();
xRequest.open('GET', browser.extension.getURL("")+sImagePath, false);
xRequest.responseType = "arraybuffer";
xRequest.send();
let blobTxt = new Blob([xRequest.response], {type: 'image/png'});
let img = document.createElement('img');
img.src = (URL || webkitURL).createObjectURL(blobTxt); // webkitURL is obsolete: https://bugs.webkit.org/show_bug.cgi?id=167518
Array.filter(document.getElementsByClassName(sContainerClass), function (oElem) {
oElem.appendChild(img);
});
}