DELETED gc_lang/fr/webext/content_scripts/content_panels.css Index: gc_lang/fr/webext/content_scripts/content_panels.css ================================================================== --- gc_lang/fr/webext/content_scripts/content_panels.css +++ gc_lang/fr/webext/content_scripts/content_panels.css @@ -1,143 +0,0 @@ -/* - CSS - Content panels for Grammalecte -*/ - - -/* - Wrapper -*/ -.grammalecte_wrapper { - padding: 5px; - border-radius: 3px; - background-color: hsl(210, 50%, 50%); - font-family: "Trebuchet MS", "Liberation Sans", sans-serif; - color: hsl(210, 10%, 90%); -} - -.grammalecte_wrapper_button { - display: inline-block; - padding: 0 5px; - margin-left: 5px; - background-color: hsl(210, 50%, 60%); - border-radius: 2px; - color: hsl(210, 0%, 96%); - cursor: pointer; -} -.grammalecte_wrapper_button:hover { - background-color: hsl(210, 50%, 55%); - box-shadow: 0 0 1px 1px hsl(210, 50%, 20%); - color: hsl(210, 0%, 100%); -} -.grammalecte_wrapper_toolbar { - display: flex; - justify-content: flex-end; - margin-top: 5px; - padding: 5px 10px; -} - -/* - Panels -*/ -.grammalecte_panel { - padding: 0; - margin: 0; - position: fixed; - z-index: 100; - border: 2px solid hsl(210, 0%, 50%); - border-radius: 10px 10px 10px 10px; - background-color: hsl(210, 20%, 100%); - color: hsl(210, 10%, 4%); - font-family: "Trebuchet MS", "Liberation Sans", sans-serif; - box-shadow: 0 0 4px 2px hsl(210, 0%, 50%); -} - -.grammalecte_panel_bar { - position: sticky; - width: 100%; - background-color: hsl(210, 0%, 90%); - border-radius: 10px 10px 0 0; - border-bottom: 1px solid hsl(210, 10%, 80%); - font-size: 20px; -} -.grammalecte_panel_title { - padding: 10px 20px; -} -.grammalecte_panel_label { - display: inline-block; - padding: 0 10px; -} - -.grammalecte_panel_commands { - float: right; -} -.grammalecte_move_button { - display: inline-block; - padding: 2px 5px; - background-color: hsl(180, 80%, 50%); - font-size: 22px; - font-weight: bold; - color: hsl(210, 0%, 100%); - text-align: center; - cursor: pointer; -} -.grammalecte_move_button:hover { - background-color: hsl(180, 100%, 60%); -} -.grammalecte_close_button { - display: inline-block; - padding: 2px 10px; - border-radius: 0 8px 0 0; - background-color: hsl(0, 80%, 50%); - font-size: 22px; - font-weight: bold; - color: hsl(210, 0%, 100%); - text-align: center; - cursor: pointer; -} -.grammalecte_close_button:hover { - background-color: hsl(0, 100%, 60%); -} - -.grammalecte_panel_content { - height: calc(100% - 55px); /* panel height - title_bar */ - overflow: auto; -} - - -/* - CSS Spinner - Double bounce - http://tobiasahlin.com/spinkit/ -*/ -.grammalecte_spinner { - visibility: hidden; - width: 40px; - height: 40px; - position: absolute; - top: 2px; - right: 150px; -} -.grammalecte_spinner .bounce1, -.grammalecte_spinner .bounce2 { - width: 100%; - height: 100%; - border-radius: 50%; - background-color: hsl(0, 50%, 75%); - opacity: 0.6; - position: absolute; - top: 0; - left: 0; - animation: grammalecte-sk-bounce 2.0s infinite ease-in-out; -} -.grammalecte_spinner .bounce2 { - animation-delay: -1.0s; -} - -@keyframes grammalecte-sk-bounce { - 0%, 100% { - transform: scale(0.0); - } 50% { - transform: scale(1.0); - } -} DELETED gc_lang/fr/webext/content_scripts/panel_creator.js Index: gc_lang/fr/webext/content_scripts/panel_creator.js ================================================================== --- gc_lang/fr/webext/content_scripts/panel_creator.js +++ gc_lang/fr/webext/content_scripts/panel_creator.js @@ -1,168 +0,0 @@ -// JavaScript -// Panel creator - -"use strict"; - -console.log("[Content script] Panel creator"); - - -class GrammalectePanel { - - constructor (sId, sTitle, nWidth, nHeight, bMovable=true) { - this.sId = sId; - this.sContentId = sId+"_content"; - this.nWidth = nWidth; - this.nHeight = nHeight; - this.bMovable = bMovable; - this.xContentNode = createNode("div", {className: "grammalecte_panel_content"}); - this.xWaitIcon = this._createWaitIcon(); - this.xPanelNode = this._createPanel(sTitle); - this.center(); - } - - _createPanel (sTitle) { - try { - let xPanel = createNode("div", {id: this.sId, className: "grammalecte_panel"}); - let xBar = createNode("div", {className: "grammalecte_panel_bar"}); - xBar.appendChild(this._createButtons()); - let xTitle = createNode("div", {className: "grammalecte_panel_title"}); - xTitle.appendChild(createLogo()); - xTitle.appendChild(createNode("div", {className: "grammalecte_panel_label", textContent: sTitle})); - xBar.appendChild(xTitle); - xPanel.appendChild(xBar); - xPanel.appendChild(this.xContentNode); - return xPanel; - } - catch (e) { - showError(e); - } - } - - _createButtons () { - let xButtonLine = createNode("div", {className: "grammalecte_panel_commands"}); - xButtonLine.appendChild(this.xWaitIcon); - if (this.bMovable) { - xButtonLine.appendChild(this._createMoveButton("stickToTop", "¯", "Coller en haut")); - xButtonLine.appendChild(this._createMoveButton("stickToLeft", "«", "Coller à gauche")); - xButtonLine.appendChild(this._createMoveButton("center", "•", "Centrer")); - xButtonLine.appendChild(this._createMoveButton("stickToRight", "»", "Coller à droite")); - xButtonLine.appendChild(this._createMoveButton("stickToBottom", "_", "Coller en bas")); - } - xButtonLine.appendChild(this._createCloseButton()); - return xButtonLine; - } - - _createWaitIcon () { - let xWaitIcon = createNode("div", {className: "grammalecte_spinner"}); - xWaitIcon.appendChild(createNode("div", {className: "bounce1"})); - xWaitIcon.appendChild(createNode("div", {className: "bounce2"})); - return xWaitIcon; - } - - _createMoveButton (sAction, sLabel, sTitle) { - let xButton = createNode("div", {className: "grammalecte_move_button", textContent: sLabel, title: sTitle}); - xButton.onclick = function () { this[sAction](); }.bind(this); - return xButton; - } - - _createCloseButton () { - let xButton = createNode("div", {className: "grammalecte_close_button", textContent: "×", title: "Fermer la fenêtre"}); - xButton.onclick = function () { this.hide(); }.bind(this); // better than writing “let that = this;” before the function? - return xButton; - } - - setContentNode (xNode) { - this.xContentNode.appendChild(xNode); - } - - insertIntoPage () { - document.body.appendChild(this.xPanelNode); - } - - show () { - this.xPanelNode.style.display = "block"; - } - - hide () { - this.xPanelNode.style.display = "none"; - } - - center () { - let nHeight = window.innerHeight-100; - this.xPanelNode.style = `top: 50%; left: 50%; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px; margin-left: -${this.nWidth/2}px;`; - } - - stickToLeft () { - let nHeight = window.innerHeight-100; - this.xPanelNode.style = `top: 50%; left: -2px; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px;`; - } - - stickToRight () { - let nHeight = window.innerHeight-100; - this.xPanelNode.style = `top: 50%; right: -2px; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px;`; - } - - stickToTop () { - let nWidth = Math.floor(window.innerWidth/2); - this.xPanelNode.style = `top: -2px; left: 50%; width: ${nWidth}px; height: ${Math.floor(window.innerHeight*0.45)}px; margin-left: -${nWidth/2}px;`; - } - - stickToBottom () { - let nWidth = Math.floor(window.innerWidth/2); - this.xPanelNode.style = `bottom: -2px; left: 50%; width: ${nWidth}px; height: ${Math.floor(window.innerHeight*0.45)}px; margin-left: -${nWidth/2}px;`; - } - - reduce () { - // todo - } - - logInnerHTML () { - // for debugging - console.log(this.xPanelNode.innerHTML); - } - - startWaitIcon () { - this.xWaitIcon.style.visibility = "visible"; - } - - stopWaitIcon () { - this.xWaitIcon.style.visibility = "hidden"; - } -} - - -/* - Common functions -*/ -function createNode (sType, oAttr, oDataset=null) { - try { - let xNode = document.createElement(sType); - Object.assign(xNode, oAttr); - if (oDataset) { - Object.assign(xNode.dataset, oDataset); - } - return xNode; - } - catch (e) { - showError(e); - } -} - -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); - }); -} ADDED gc_lang/fr/webext/content_scripts/panels_content.css Index: gc_lang/fr/webext/content_scripts/panels_content.css ================================================================== --- gc_lang/fr/webext/content_scripts/panels_content.css +++ gc_lang/fr/webext/content_scripts/panels_content.css @@ -0,0 +1,143 @@ +/* + CSS + Content panels for Grammalecte +*/ + + +/* + Wrapper +*/ +.grammalecte_wrapper { + padding: 5px; + border-radius: 3px; + background-color: hsl(210, 50%, 50%); + font-family: "Trebuchet MS", "Liberation Sans", sans-serif; + color: hsl(210, 10%, 90%); +} + +.grammalecte_wrapper_button { + display: inline-block; + padding: 0 5px; + margin-left: 5px; + background-color: hsl(210, 50%, 60%); + border-radius: 2px; + color: hsl(210, 0%, 96%); + cursor: pointer; +} +.grammalecte_wrapper_button:hover { + background-color: hsl(210, 50%, 55%); + box-shadow: 0 0 1px 1px hsl(210, 50%, 20%); + color: hsl(210, 0%, 100%); +} +.grammalecte_wrapper_toolbar { + display: flex; + justify-content: flex-end; + margin-top: 5px; + padding: 5px 10px; +} + +/* + Panels +*/ +.grammalecte_panel { + padding: 0; + margin: 0; + position: fixed; + z-index: 100; + border: 2px solid hsl(210, 0%, 50%); + border-radius: 10px 10px 10px 10px; + background-color: hsl(210, 20%, 100%); + color: hsl(210, 10%, 4%); + font-family: "Trebuchet MS", "Liberation Sans", sans-serif; + box-shadow: 0 0 4px 2px hsl(210, 0%, 50%); +} + +.grammalecte_panel_bar { + position: sticky; + width: 100%; + background-color: hsl(210, 0%, 90%); + border-radius: 10px 10px 0 0; + border-bottom: 1px solid hsl(210, 10%, 80%); + font-size: 20px; +} +.grammalecte_panel_title { + padding: 10px 20px; +} +.grammalecte_panel_label { + display: inline-block; + padding: 0 10px; +} + +.grammalecte_panel_commands { + float: right; +} +.grammalecte_move_button { + display: inline-block; + padding: 2px 5px; + background-color: hsl(180, 80%, 50%); + font-size: 22px; + font-weight: bold; + color: hsl(210, 0%, 100%); + text-align: center; + cursor: pointer; +} +.grammalecte_move_button:hover { + background-color: hsl(180, 100%, 60%); +} +.grammalecte_close_button { + display: inline-block; + padding: 2px 10px; + border-radius: 0 8px 0 0; + background-color: hsl(0, 80%, 50%); + font-size: 22px; + font-weight: bold; + color: hsl(210, 0%, 100%); + text-align: center; + cursor: pointer; +} +.grammalecte_close_button:hover { + background-color: hsl(0, 100%, 60%); +} + +.grammalecte_panel_content { + height: calc(100% - 55px); /* panel height - title_bar */ + overflow: auto; +} + + +/* + CSS Spinner + Double bounce + http://tobiasahlin.com/spinkit/ +*/ +.grammalecte_spinner { + visibility: hidden; + width: 40px; + height: 40px; + position: absolute; + top: 2px; + right: 150px; +} +.grammalecte_spinner .bounce1, +.grammalecte_spinner .bounce2 { + width: 100%; + height: 100%; + border-radius: 50%; + background-color: hsl(0, 50%, 75%); + opacity: 0.6; + position: absolute; + top: 0; + left: 0; + animation: grammalecte-sk-bounce 2.0s infinite ease-in-out; +} +.grammalecte_spinner .bounce2 { + animation-delay: -1.0s; +} + +@keyframes grammalecte-sk-bounce { + 0%, 100% { + transform: scale(0.0); + } 50% { + transform: scale(1.0); + } +} ADDED gc_lang/fr/webext/content_scripts/panels_content.js Index: gc_lang/fr/webext/content_scripts/panels_content.js ================================================================== --- gc_lang/fr/webext/content_scripts/panels_content.js +++ gc_lang/fr/webext/content_scripts/panels_content.js @@ -0,0 +1,168 @@ +// JavaScript +// Panel creator + +"use strict"; + +console.log("[Content script] Panel creator"); + + +class GrammalectePanel { + + constructor (sId, sTitle, nWidth, nHeight, bMovable=true) { + this.sId = sId; + this.sContentId = sId+"_content"; + this.nWidth = nWidth; + this.nHeight = nHeight; + this.bMovable = bMovable; + this.xContentNode = createNode("div", {className: "grammalecte_panel_content"}); + this.xWaitIcon = this._createWaitIcon(); + this.xPanelNode = this._createPanel(sTitle); + this.center(); + } + + _createPanel (sTitle) { + try { + let xPanel = createNode("div", {id: this.sId, className: "grammalecte_panel"}); + let xBar = createNode("div", {className: "grammalecte_panel_bar"}); + xBar.appendChild(this._createButtons()); + let xTitle = createNode("div", {className: "grammalecte_panel_title"}); + xTitle.appendChild(createLogo()); + xTitle.appendChild(createNode("div", {className: "grammalecte_panel_label", textContent: sTitle})); + xBar.appendChild(xTitle); + xPanel.appendChild(xBar); + xPanel.appendChild(this.xContentNode); + return xPanel; + } + catch (e) { + showError(e); + } + } + + _createButtons () { + let xButtonLine = createNode("div", {className: "grammalecte_panel_commands"}); + xButtonLine.appendChild(this.xWaitIcon); + if (this.bMovable) { + xButtonLine.appendChild(this._createMoveButton("stickToTop", "¯", "Coller en haut")); + xButtonLine.appendChild(this._createMoveButton("stickToLeft", "«", "Coller à gauche")); + xButtonLine.appendChild(this._createMoveButton("center", "•", "Centrer")); + xButtonLine.appendChild(this._createMoveButton("stickToRight", "»", "Coller à droite")); + xButtonLine.appendChild(this._createMoveButton("stickToBottom", "_", "Coller en bas")); + } + xButtonLine.appendChild(this._createCloseButton()); + return xButtonLine; + } + + _createWaitIcon () { + let xWaitIcon = createNode("div", {className: "grammalecte_spinner"}); + xWaitIcon.appendChild(createNode("div", {className: "bounce1"})); + xWaitIcon.appendChild(createNode("div", {className: "bounce2"})); + return xWaitIcon; + } + + _createMoveButton (sAction, sLabel, sTitle) { + let xButton = createNode("div", {className: "grammalecte_move_button", textContent: sLabel, title: sTitle}); + xButton.onclick = function () { this[sAction](); }.bind(this); + return xButton; + } + + _createCloseButton () { + let xButton = createNode("div", {className: "grammalecte_close_button", textContent: "×", title: "Fermer la fenêtre"}); + xButton.onclick = function () { this.hide(); }.bind(this); // better than writing “let that = this;” before the function? + return xButton; + } + + setContentNode (xNode) { + this.xContentNode.appendChild(xNode); + } + + insertIntoPage () { + document.body.appendChild(this.xPanelNode); + } + + show () { + this.xPanelNode.style.display = "block"; + } + + hide () { + this.xPanelNode.style.display = "none"; + } + + center () { + let nHeight = window.innerHeight-100; + this.xPanelNode.style = `top: 50%; left: 50%; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px; margin-left: -${this.nWidth/2}px;`; + } + + stickToLeft () { + let nHeight = window.innerHeight-100; + this.xPanelNode.style = `top: 50%; left: -2px; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px;`; + } + + stickToRight () { + let nHeight = window.innerHeight-100; + this.xPanelNode.style = `top: 50%; right: -2px; width: ${this.nWidth}px; height: ${nHeight}px; margin-top: -${nHeight/2}px;`; + } + + stickToTop () { + let nWidth = Math.floor(window.innerWidth/2); + this.xPanelNode.style = `top: -2px; left: 50%; width: ${nWidth}px; height: ${Math.floor(window.innerHeight*0.45)}px; margin-left: -${nWidth/2}px;`; + } + + stickToBottom () { + let nWidth = Math.floor(window.innerWidth/2); + this.xPanelNode.style = `bottom: -2px; left: 50%; width: ${nWidth}px; height: ${Math.floor(window.innerHeight*0.45)}px; margin-left: -${nWidth/2}px;`; + } + + reduce () { + // todo + } + + logInnerHTML () { + // for debugging + console.log(this.xPanelNode.innerHTML); + } + + startWaitIcon () { + this.xWaitIcon.style.visibility = "visible"; + } + + stopWaitIcon () { + this.xWaitIcon.style.visibility = "hidden"; + } +} + + +/* + Common functions +*/ +function createNode (sType, oAttr, oDataset=null) { + try { + let xNode = document.createElement(sType); + Object.assign(xNode, oAttr); + if (oDataset) { + Object.assign(xNode.dataset, oDataset); + } + return xNode; + } + catch (e) { + showError(e); + } +} + +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); + }); +}