Index: gc_lang/fr/webext/content_scripts/content_modifier.js ================================================================== --- gc_lang/fr/webext/content_scripts/content_modifier.js +++ gc_lang/fr/webext/content_scripts/content_modifier.js @@ -112,11 +112,11 @@ oLxgPanelContent.clear(); oLxgPanel.show(); } else { // create the panel oLxgPanel = new GrammalectePanel("grammalecte_lxg_panel", "Lexicographe", 500, 700); - oLxgPanel.setContentNode(oLxgPanelContent.getNode()); + oLxgPanel.setContentNode(oLxgPanelContent.init()); oLxgPanel.insertIntoPage(); } } function createGCPanel () { @@ -125,11 +125,11 @@ oGCPanelContent.clear(); oGCPanel.show(); } else { // create the panel oGCPanel = new GrammalectePanel("grammalecte_gc_panel", "Correcteur", 500, 700); - oGCPanel.setContentNode(oGCPanelContent.getNode()); + oGCPanel.setContentNode(oGCPanelContent.init()); oGCPanel.insertIntoPage(); } } 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 @@ -101,5 +101,42 @@ .grammalecte_panel_content { height: calc(100% - 55px); /* panel height - title_bar */ overflow: auto; } + + +/* + CSS Spinner + Double bounce + http://tobiasahlin.com/spinkit/ +*/ +.grammalecte_spinner { + width: 30px; + height: 30px; + position: absolute; + top: 2px; + right: 120px; +} +.grammalecte_spinner .bounce1, +.grammalecte_spinner .bounce2 { + width: 100%; + height: 100%; + border-radius: 50%; + background-color: hsl(180, 50%, 75%); + opacity: 0.6; + position: absolute; + top: 0; + left: 0; + animation: grammalecte-sk-bounce 2.0s infinite ease-in-out; +} +.bounce2 { + animation-delay: -1.0s; +} + +@keyframes grammalecte-sk-bounce { + 0%, 100% { + transform: scale(0.0); + } 50% { + transform: scale(1.0); + } +} Index: gc_lang/fr/webext/content_scripts/gc_content.css ================================================================== --- gc_lang/fr/webext/content_scripts/gc_content.css +++ gc_lang/fr/webext/content_scripts/gc_content.css @@ -55,15 +55,92 @@ } .grammalecte_paragraph u.error:hover { cursor: pointer; } + +.grammalecte_paragraph_actions { + margin: 0 0 5px 10px; +} +.grammalecte_paragraph_actions .close_button { + background-color: hsl(0, 0%, 50%); + text-align: center; + float: right; + margin-left: 2px; + padding: 1px 4px 3px 4px; + cursor: pointer; + font-size: 14px; + color: hsl(0, 0%, 96%); + border-radius: 2px; + background-color: hsl(0, 30%, 50%); + color: hsl(0, 0%, 96%); +} + + +/* + Action buttons +*/ + +.grammalecte_actions { + margin: 0 0 5px 10px; +} + +.grammalecte_actions .button { + background-color: hsl(0, 0%, 50%); + text-align: center; + float: right; + margin-left: 2px; + padding: 1px 4px 3px 4px; + cursor: pointer; + font-size: 14px; + color: hsl(0, 0%, 96%); + border-radius: 2px; +} +.grammalecte_actions .button:hover { + background-color: hsl(0, 0%, 40%); + color: hsl(0, 0%, 100%); +} + +.grammalecte_actions .green { + background-color: hsl(120, 30%, 50%); + color: hsl(0, 0%, 96%); +} +.grammalecte_actions .green:hover { + background-color: hsl(120, 50%, 40%); + color: hsl(0, 0%, 100%); +} +.grammalecte_actions .red { + background-color: hsl(0, 30%, 50%); + color: hsl(0, 0%, 96%); +} +.grammalecte_actions .red:hover { + background-color: hsl(0, 50%, 40%); + color: hsl(0, 0%, 100%); +} +.grammalecte_actions .orange { + background-color: hsl(30, 50%, 50%); + color: hsl(30, 0%, 96%); +} +.grammalecte_actions .orange:hover { + background-color: hsl(30, 70%, 40%); + color: hsl(30, 0%, 100%); +} +.grammalecte_actions .bold { + font-weight: bold; +} + + /* - TOOLTIPS + TOOLTIP */ -.tooltip { +#grammalecte_tooltip_arrow { + position: absolute; + display: none; +} + +#grammalecte_tooltip { position: absolute; display: none; width: 300px; border-radius: 5px; box-shadow: 0 0 6px hsla(0, 0%, 0%, 0.3); @@ -70,135 +147,98 @@ font-family: Tahoma, "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", sans-serif; font-size: 12px; line-height: 18px; cursor: default; text-decoration: none; -} -#gc_tooltip { border: 3px solid hsl(210, 50%, 30%); color: hsla(210, 10%, 20%, 1); -} -#sc_tooltip { - border: 3px solid hsl(0, 50%, 30%); - color: hsla(0, 10%, 20%, 1); -} -#gc_tooltip_arrow, #sc_tooltip_arrow { - position: absolute; - display: none; -} -#gc_tooltip #gc_rule_id { - display: none; - margin: 0 0 5px 0; + z-index: 1000; +} + +#grammalecte_tooltip_message_block { + padding: 5px 10px 10px 10px; + background-color: hsl(210, 50%, 30%); + color: hsl(210, 50%, 96%); +} +#grammalecte_tooltip_rule_id { + display: none; + margin-bottom: 5px; border: 1px solid hsl(210, 50%, 60%); background-color: hsl(210, 50%, 40%); padding: 2px 5px; border-radius: 2px; color: hsla(210, 0%, 96%, 1); font-size: 11px; font-style: normal; text-align: center; } -#gc_message_block { - padding: 5px 10px 10px 10px; - background-color: hsl(210, 50%, 30%); - color: hsl(210, 50%, 96%); -} -#sc_message_block { - padding: 5px 10px 10px 10px; - background-color: hsl(0, 50%, 30%); - color: hsl(0, 50%, 96%); -} -#gc_message, #sc_message { +#grammalecte_tooltip_message { font-size: 15px; margin-bottom: 5px; } -a#gc_ignore, a#sc_ignore { +a#grammalecte_tooltip_ignore { padding: 0 2px; background-color: hsla(30, 30%, 40%, 1); color: hsla(30, 0%, 96%, 1); border-radius: 2px; cursor: pointer; text-decoration: none; } -a#gc_ignore:hover, a#sc_ignore:hover { +a#grammalecte_tooltip_ignore:hover { background-color: hsla(30, 30%, 50%, 1); color: hsla(0, 0%, 100%, 1); text-shadow: 0 0 3px hsl(30, 30%, 60%); } -a#gc_url { +a#grammalecte_tooltip_url { padding: 0 2px; background-color: hsla(210, 50%, 50%, 1); color: hsla(210, 0%, 96%, 1); border-radius: 2px; cursor: pointer; text-decoration: none; } -a#gc_url:hover { +a#grammalecte_tooltip_url:hover { background-color: hsla(210, 50%, 60%, 1); color: hsla(0, 0%, 100%, 1); text-shadow: 0 0 3px hsl(210, 30%, 60%); } -#gc_sugg_title { +#grammalecte_tooltip_sugg_title { padding: 0 10px; background-color: hsl(210, 10%, 90%); color: hsl(210, 50%, 30%); font-size: 10px; font-weight: bold; } -#sc_sugg_title { - padding: 0 10px; - background-color: hsl(0, 10%, 90%); - color: hsl(0, 50%, 30%); - font-size: 9px; - font-weight: bold; -} -#gc_sugg_block { +#grammalecte_tooltip_sugg_block { padding: 10px; background-color: hsl(210, 10%, 96%); border-radius: 0 0 2px 2px; line-height: 20px; } -#sc_sugg_block { - padding: 10px; - background-color: hsl(0, 10%, 96%); - border-radius: 0 0 2px 2px; - line-height: 20px; -} -#gc_sugg_block a.sugg { +#grammalecte_tooltip_sugg_block a.sugg { padding: 1px 6px; background-color: hsla(180, 60%, 40%, 1); color: hsla(180, 0%, 96%, 1); border-radius: 2px; cursor: pointer; text-decoration: none; } -#gc_sugg_block a.sugg:hover { +#grammalecte_tooltip_sugg_block a.sugg:hover { background-color: hsla(180, 70%, 45%, 1); color: hsla(0, 0%, 100%, 1); } -#sc_sugg_block a.sugg { - padding: 1px 6px; - background-color: hsla(30, 90%, 45%, 1); - color: hsla(30, 0%, 96%, 1); - border-radius: 2px; - cursor: pointer; - text-decoration: none; -} -#sc_sugg_block a.sugg:hover { - background-color: hsla(30, 100%, 50%, 1); - color: hsla(0, 0%, 100%, 1); -} + /* Action buttons */ -.actions { +.grammalecte_paragraph_actions { margin: 0 0 5px 10px; } -.actions .button { +.grammalecte_paragraph_actions .button { background-color: hsl(0, 0%, 50%); text-align: center; float: right; margin-left: 2px; padding: 1px 4px 3px 4px; @@ -207,129 +247,185 @@ cursor: pointer; font-size: 14px; color: hsl(0, 0%, 96%); border-radius: 2px; } -.actions .button:hover { +.grammalecte_paragraph_actions .button:hover { background-color: hsl(0, 0%, 40%); color: hsl(0, 0%, 100%); } -.actions .green { +.grammalecte_paragraph_actions .green { background-color: hsl(120, 30%, 50%); color: hsl(0, 0%, 96%); } -.actions .green:hover { +.grammalecte_paragraph_actions .green:hover { background-color: hsl(120, 50%, 40%); color: hsl(0, 0%, 100%); } -.actions .red { +.grammalecte_paragraph_actions .red { background-color: hsl(0, 30%, 50%); color: hsl(0, 0%, 96%); } -.actions .red:hover { +.grammalecte_paragraph_actions .red:hover { background-color: hsl(0, 50%, 40%); color: hsl(0, 0%, 100%); } -.actions .orange { +.grammalecte_paragraph_actions .orange { background-color: hsl(30, 50%, 50%); color: hsl(30, 0%, 96%); } -.actions .orange:hover { +.grammalecte_paragraph_actions .orange:hover { background-color: hsl(30, 70%, 40%); color: hsl(30, 0%, 100%); } -.actions .bold { +.grammalecte_paragraph_actions .bold { font-weight: bold; } /* ERRORS */ -.error { +.grammalecte_paragraph .error { /* default color */ background-color: hsl(240, 10%, 50%); color: hsl(240, 0%, 96%); } -.error:hover { +.grammalecte_paragraph .error:hover { background-color: hsl(240, 10%, 40%); color: hsl(240, 0%, 100%); } /* elems */ -.WORD { +.grammalecte_paragraph .WORD { background-color: hsl(0, 50%, 50%); color: hsl(0, 0%, 96%); /*text-decoration: underline wavy hsl(0, 50%, 50%);*/ } -.WORD:hover { +.grammalecte_paragraph .WORD:hover { background-color: hsl(0, 60%, 40%); color: hsl(0, 0%, 100%); } /* elems */ -.typo, .esp, .nbsp, .eif, .maj, .virg, .tu, .num, .unit, .nf, .liga, .mapos, .chim { +.grammalecte_paragraph .typo, +.grammalecte_paragraph .esp, +.grammalecte_paragraph .nbsp, +.grammalecte_paragraph .eif, +.grammalecte_paragraph .maj, +.grammalecte_paragraph .virg, +.grammalecte_paragraph .tu, +.grammalecte_paragraph .num, +.grammalecte_paragraph .unit, +.grammalecte_paragraph .nf, +.grammalecte_paragraph .liga, +.grammalecte_paragraph .mapos, +.grammalecte_paragraph .chim { background-color: hsl(30, 70%, 50%); color: hsl(30, 10%, 96%); /*text-decoration: underline wavy hsl(30, 70%, 50%);*/ } -.typo:hover, .esp:hover, .nbsp:hover, .eif:hover, .maj:hover, .virg:hover, .tu:hover, .num:hover, .unit:hover, .nf:hover, .liga:hover, .mapos:hover, .chim:hover { + +.grammalecte_paragraph .typo:hover, +.grammalecte_paragraph .esp:hover, +.grammalecte_paragraph .nbsp:hover, +.grammalecte_paragraph .eif:hover, +.grammalecte_paragraph .maj:hover, +.grammalecte_paragraph .virg:hover, +.grammalecte_paragraph .tu:hover, +.grammalecte_paragraph .num:hover, +.grammalecte_paragraph .unit:hover, +.grammalecte_paragraph .nf:hover, +.grammalecte_paragraph .liga:hover, +.grammalecte_paragraph .mapos:hover, +.grammalecte_paragraph .chim:hover { background-color: hsl(30, 80%, 45%); color: hsl(30, 10%, 96%); } /* elems */ -.apos { +.grammalecte_paragraph .apos { background-color: hsl(40, 90%, 50%); color: hsl(40, 10%, 96%); /*text-decoration: underline wavy hsl(40, 70%, 45%);*/ } -.apos:hover { +.grammalecte_paragraph .apos:hover { background-color: hsl(40, 100%, 45%); color: hsl(40, 10%, 96%); } /* elems */ -.gn, .sgpl { +.grammalecte_paragraph .gn, +.grammalecte_paragraph .sgpl { background-color: hsl(210, 50%, 50%); color: hsl(210, 10%, 96%); /*text-decoration: underline wavy hsl(210, 50%, 50%);*/ } -.gn:hover, .sgpl:hover { +.grammalecte_paragraph .gn:hover, +.grammalecte_paragraph .sgpl:hover { background-color: hsl(210, 60%, 40%); color: hsl(210, 10%, 96%); } /* elems */ -.conj, .infi, .imp, .inte, .ppas, .vmode { +.grammalecte_paragraph .conj, +.grammalecte_paragraph .infi, +.grammalecte_paragraph .imp, +.grammalecte_paragraph .inte, +.grammalecte_paragraph .ppas, +.grammalecte_paragraph .vmode { background-color: hsl(300, 30%, 40%); color: hsl(300, 10%, 96%); /*text-decoration: underline wavy hsl(300, 40%, 40%);*/ } -.conj:hover, .infi:hover, .imp:hover, .inte:hover, .ppas:hover, .vmode:hover { + +.grammalecte_paragraph .conj:hover, +.grammalecte_paragraph .infi:hover, +.grammalecte_paragraph .imp:hover, +.grammalecte_paragraph .inte:hover, +.grammalecte_paragraph .ppas:hover, +.grammalecte_paragraph .vmode:hover { background-color: hsl(300, 40%, 30%); color: hsl(300, 10%, 96%); } /* elems */ -.conf, .ocr { +.grammalecte_paragraph .conf, +.grammalecte_paragraph .ocr { background-color: hsl(270, 40%, 30%); color: hsl(270, 10%, 96%); /*text-decoration: underline wavy hsl(270, 40%, 30%);*/ } -.conf:hover, .ocr:hover { + +.grammalecte_paragraph .conf:hover, +.grammalecte_paragraph .ocr:hover { background-color: hsl(270, 50%, 20%); color: hsl(270, 10%, 96%); } /* elems */ -.bs, .pleo, .neg, .redon1, .redon2, .mc, .date, .notype { +.grammalecte_paragraph .bs, +.grammalecte_paragraph .pleo, +.grammalecte_paragraph .neg, +.grammalecte_paragraph .redon1, +.grammalecte_paragraph .redon2, +.grammalecte_paragraph .mc, +.grammalecte_paragraph .date, +.grammalecte_paragraph .notype { background-color: hsl(180, 50%, 40%); color: hsl(180, 10%, 96%); /*text-decoration: underline wavy hsl(180, 50%, 40%);*/ } -.bs:hover, .pleo:hover, .neg:hover, .redon1:hover, .redon2:hover, .mc:hover, .date:hover, .notype:hover { + +.grammalecte_paragraph .bs:hover, +.grammalecte_paragraph .pleo:hover, +.grammalecte_paragraph .neg:hover, +.grammalecte_paragraph .redon1:hover, +.grammalecte_paragraph .redon2:hover, +.grammalecte_paragraph .mc:hover, +.grammalecte_paragraph .date:hover, +.grammalecte_paragraph .notype:hover { background-color: hsl(180, 60%, 30%); color: hsl(180, 10%, 96%); } Index: gc_lang/fr/webext/content_scripts/gc_content.js ================================================================== --- gc_lang/fr/webext/content_scripts/gc_content.js +++ gc_lang/fr/webext/content_scripts/gc_content.js @@ -1,43 +1,86 @@ // JavaScript "use strict"; + +function onGrammalecteGCPanelClick (xEvent) { + try { + let xElem = xEvent.target; + if (xElem.id) { + if (xElem.id.startsWith("sugg")) { + oGCPanelContent.applySuggestion(xElem.id); + } else if (xElem.id.endsWith("_ignore")) { + oGCPanelContent.ignoreError(xElem.id); + } else if (xElem.id.startsWith("check")) { + //oGCPanelContent.sendBackAndCheck(xElem.id); + } else if (xElem.id.startsWith("end")) { + //document.getElementById(xElem.id).parentNode.parentNode.style.display = "none"; + } else if (xElem.tagName === "U" && xElem.id.startsWith("err") + && xElem.className !== "corrected" && xElem.className !== "ignored") { + oGrammalecteTooltip.show(xElem.id); + } else if (xElem.id === "gc_url") { + oGCPanelContent.openURL(xElem.getAttribute("href")); + } else { + oGrammalecteTooltip.hide(); + } + } else if (xElem.tagName === "A") { + oGCPanelContent.openURL(xElem.getAttribute("href")); + } else { + oGrammalecteTooltip.hide(); + } + } + catch (e) { + showError(e); + } +} + const oGCPanelContent = { - _xContentNode: createNode("div", {id: "grammalecte_gc_panel_content"}), + bInitDone: false, + + xContentNode: null, + xParagraphList: null, - aIgnoredErrors: new Map(), + aIgnoredErrors: new Set(), - getNode: function () { - return this._xContentNode; + init: function () { + this.xContentNode = createNode("div", {id: "grammalecte_gc_panel_content"}); + this.xParagraphList = createNode("div", {id: "grammalecte_paragraph_list"}); + this.xContentNode.appendChild(this.xParagraphList); + this.xContentNode.addEventListener("click", onGrammalecteGCPanelClick, false); + oGrammalecteTooltip.init(); + this.xContentNode.appendChild(oGrammalecteTooltip.xTooltip); + this.bInitDone = true; + return this.xContentNode; }, clear: function () { - while (this._xContentNode.firstChild) { - this._xContentNode.removeChild(this._xContentNode.firstChild); + while (this.xParagraphList.firstChild) { + this.xParagraphList.removeChild(this.xParagraphList.firstChild); } + this.aIgnoredErrors.clear(); }, addParagraphResult: function (oResult) { try { if (oResult) { let xNodeDiv = createNode("div", {className: "grammalecte_paragraph_block"}); // actions - let xActionsBar = createNode("div", {className: "grammalecte_paragraph_actions"}); - let xCloseButton = createNode("div", {id: "end" + oResult.sParaNum, className: "grammalecte_paragraph_close_button", textContent: "×"}); - let xAnalyseButton = createNode("div", {id: "check" + oResult.sParaNum, className: "grammalecte_paragraph_analyse_button", textContent: "Réanalyser"}); + let xActionsBar = createNode("div", {className: "grammalecte_actions"}); + let xCloseButton = createNode("div", {id: "end" + oResult.sParaNum, className: "button red blod", textContent: "×"}); + let xAnalyseButton = createNode("div", {id: "check" + oResult.sParaNum, className: "button green", textContent: "Réanalyser"}); xActionsBar.appendChild(xAnalyseButton); xActionsBar.appendChild(xCloseButton); // paragraph let xParagraph = createNode("p", {id: "paragr"+oResult.sParaNum, lang: "fr", spellcheck: "false", contenteditable: "true"}); xParagraph.className = (oResult.aGrammErr.length || oResult.aSpellErr.length) ? "grammalecte_paragraph softred" : "grammalecte_paragraph"; this._tagParagraph(xParagraph, oResult.sParagraph, oResult.sParaNum, oResult.aGrammErr, oResult.aSpellErr); // creation xNodeDiv.appendChild(xActionsBar); xNodeDiv.appendChild(xParagraph); - this._xContentNode.appendChild(xNodeDiv); + this.xParagraphList.appendChild(xNodeDiv); } } catch (e) { showError(e); } @@ -117,18 +160,16 @@ applySuggestion: function (sSuggId) { // sugg try { let sErrorId = document.getElementById(sSuggId).dataset.error_id; let sIdParagr = sErrorId.slice(0, sErrorId.indexOf("_")); - startWaitIcon("paragr"+sIdParagr); let xNodeErr = document.getElementById("err" + sErrorId); xNodeErr.textContent = document.getElementById(sSuggId).textContent; xNodeErr.className = "corrected"; xNodeErr.removeAttribute("style"); - self.port.emit("correction", sIdParagr, getPurgedTextOfParagraph("paragr"+sIdParagr)); - this.hideAllTooltips(); - stopWaitIcon("paragr"+sIdParagr); + //self.port.emit("correction", sIdParagr, getPurgedTextOfParagraph("paragr"+sIdParagr)); + oGrammalecteTooltip.hide(); } catch (e) { showError(e); } }, @@ -138,48 +179,115 @@ //console.log("ignore button: " + sIgnoreButtonId + " // error id: " + document.getElementById(sIgnoreButtonId).dataset.error_id); let xNodeErr = document.getElementById("err"+document.getElementById(sIgnoreButtonId).dataset.error_id); this.aIgnoredErrors.add(xNodeErr.dataset.ignored_key); xNodeErr.className = "ignored"; xNodeErr.removeAttribute("style"); - this.hideAllTooltips(); + oGrammalecteTooltip.hide(); } catch (e) { showError(e); } }, - showTooltip: function (sNodeErrorId) { // err + addSummary: function () { + // todo + }, + + addMessage: function (sMessage) { + let xNode = createNode("div", {className: "grammalecte_gc_panel_message", textContent: sMessage}); + this.xParagraphList.appendChild(xNode); + }, + + copyToClipboard: function () { + startWaitIcon(); try { - this.hideAllTooltips(); + let xClipboardButton = document.getElementById("clipboard_msg"); + xClipboardButton.textContent = "copie en cours…"; + let sText = ""; + for (let xNode of document.getElementById("errorlist").getElementsByClassName("paragraph")) { + sText += xNode.textContent + "\n"; + } + self.port.emit('copyToClipboard', sText); + xClipboardButton.textContent = "-> presse-papiers"; + window.setTimeout(function() { xClipboardButton.textContent = "∑"; } , 3000); + } + catch (e) { + console.log(e.lineNumber + ": " +e.message); + } + stopWaitIcon(); + } +} + + + +function sendBackAndCheck (sCheckButtonId) { // check + startWaitIcon(); + let sIdParagr = sCheckButtonId.slice(5); + self.port.emit("modifyAndCheck", sIdParagr, getPurgedTextOfParagraph("paragr"+sIdParagr)); + stopWaitIcon(); +} + +function getPurgedTextOfParagraph (sNodeParagrId) { + let sText = document.getElementById(sNodeParagrId).textContent; + sText = sText.replace(/ /g, " ").replace(/</g, "<").replace(/>/g, ">").replace(/&/g, "&"); + return sText; +} + + +const oGrammalecteTooltip = { + + xTooltip: null, + + xTooltipArrow: createNode("img", { + id: "grammalecte_tooltip_arrow", + src: "", + alt: "^" + }), + + xTooltipSuggBlock: null, + + init: function () { + this.xTooltip = createNode("div", {id: "grammalecte_tooltip"}); + let xMessageBlock = createNode("div", {id: "grammalecte_tooltip_message_block"}); + xMessageBlock.appendChild(createNode("p", {id: "grammalecte_tooltip_rule_id"})); + xMessageBlock.appendChild(createNode("p", {id: "grammalecte_tooltip_message", textContent: "Erreur."})); + xMessageBlock.appendChild(createNode("a", {id: "grammalecte_tooltip_ignore", href: "#", onclick: "return false;", textContent: "Ignorer"})); + xMessageBlock.appendChild(createNode("a", {id: "grammalecte_tooltip_url", href: "#", onclick: "return false;", textContent: "Voulez-vous en savoir plus ?…"})); + this.xTooltip.appendChild(xMessageBlock); + this.xTooltip.appendChild(createNode("div", {id: "grammalecte_tooltip_sugg_title", textContent: "SUGGESTIONS :"})); + this.xTooltipSuggBlock = createNode("div", {id: "grammalecte_tooltip_sugg_block"}); + this.xTooltip.appendChild(this.xTooltipSuggBlock); + }, + + show: function (sNodeErrorId) { // err + try { let xNodeErr = document.getElementById(sNodeErrorId); - let sTooltipId = (xNodeErr.dataset.error_type === "grammar") ? "gc_tooltip" : "sc_tooltip"; - let xNodeTooltip = document.getElementById(sTooltipId); - let xNodeTooltipArrow = document.getElementById(sTooltipId+"_arrow"); - let nLimit = nPanelWidth - 330; // paragraph width - tooltip width - xNodeTooltipArrow.style.top = (xNodeErr.offsetTop + 16) + "px" - xNodeTooltipArrow.style.left = (xNodeErr.offsetLeft + Math.floor((xNodeErr.offsetWidth / 2))-4) + "px" // 4 is half the width of the arrow. - xNodeTooltip.style.top = (xNodeErr.offsetTop + 20) + "px"; - xNodeTooltip.style.left = (xNodeErr.offsetLeft > nLimit) ? nLimit + "px" : xNodeErr.offsetLeft + "px"; + let nLimit = 500 - 330; // paragraph width - tooltip width + this.xTooltipArrow.style.top = (xNodeErr.offsetTop + 16) + "px" + this.xTooltipArrow.style.left = (xNodeErr.offsetLeft + Math.floor((xNodeErr.offsetWidth / 2))-4) + "px" // 4 is half the width of the arrow. + this.xTooltip.style.top = (xNodeErr.offsetTop + 20) + "px"; + this.xTooltip.style.left = (xNodeErr.offsetLeft > nLimit) ? nLimit + "px" : xNodeErr.offsetLeft + "px"; if (xNodeErr.dataset.error_type === "grammar") { // grammar error if (xNodeErr.dataset.gc_message.includes(" ##")) { let n = xNodeErr.dataset.gc_message.indexOf(" ##"); - document.getElementById("gc_message").textContent = xNodeErr.dataset.gc_message.slice(0, n); - document.getElementById("gc_rule_id").textContent = "Règle : " + xNodeErr.dataset.gc_message.slice(n+2); - document.getElementById("gc_rule_id").style.display = "block"; + document.getElementById("grammalecte_tooltip_message").textContent = xNodeErr.dataset.gc_message.slice(0, n); + document.getElementById("grammalecte_tooltip_rule_id").textContent = "Règle : " + xNodeErr.dataset.gc_message.slice(n+2); + document.getElementById("grammalecte_tooltip_rule_id").style.display = "block"; } else { - document.getElementById("gc_message").textContent = xNodeErr.dataset.gc_message; + document.getElementById("grammalecte_tooltip_message").textContent = xNodeErr.dataset.gc_message; + document.getElementById("grammalecte_tooltip_rule_id").style.display = "none"; } if (xNodeErr.dataset.gc_url != "") { - document.getElementById("gc_url").style.display = "inline"; - document.getElementById("gc_url").setAttribute("href", xNodeErr.dataset.gc_url); - } else { - document.getElementById("gc_url").style.display = "none"; - } - document.getElementById("gc_ignore").dataset.error_id = xNodeErr.dataset.error_id; - let iSugg = 0; - let xGCSugg = document.getElementById("gc_sugg_block"); + document.getElementById("grammalecte_tooltip_url").style.display = "inline"; + document.getElementById("grammalecte_tooltip_url").setAttribute("href", xNodeErr.dataset.gc_url); + } else { + document.getElementById("grammalecte_tooltip_url").style.display = "none"; + } + document.getElementById("grammalecte_tooltip_ignore").dataset.error_id = xNodeErr.dataset.error_id; + let iSugg = 0; + let xGCSugg = document.getElementById("grammalecte_tooltip_sugg_block"); xGCSugg.textContent = ""; if (xNodeErr.dataset.suggestions.length > 0) { for (let sSugg of xNodeErr.dataset.suggestions.split("|")) { xGCSugg.appendChild(this._createSuggestion(xNodeErr.dataset.error_id, iSugg, sSugg)); xGCSugg.appendChild(document.createTextNode(" ")); @@ -187,23 +295,37 @@ } } else { xGCSugg.textContent = "Aucune."; } } - xNodeTooltipArrow.style.display = "block"; - xNodeTooltip.style.display = "block"; + this.xTooltipArrow.style.display = "block"; + this.xTooltip.style.display = "block"; if (xNodeErr.dataset.error_type === "spelling") { // spelling mistake - document.getElementById("sc_ignore").dataset.error_id = xNodeErr.dataset.error_id; + document.getElementById("grammalecte_tooltip_message").textContent = "Mot inconnu du dictionnaire."; + document.getElementById("grammalecte_tooltip_ignore").dataset.error_id = xNodeErr.dataset.error_id; + while (this.xTooltipSuggBlock.firstChild) { + this.xTooltipSuggBlock.removeChild(this.xTooltipSuggBlock.firstChild); + } //console.log("getSuggFor: " + xNodeErr.textContent.trim() + " // error_id: " + xNodeErr.dataset.error_id); - self.port.emit("getSuggestionsForTo", xNodeErr.textContent.trim(), xNodeErr.dataset.error_id); + //self.port.emit("getSuggestionsForTo", xNodeErr.textContent.trim(), xNodeErr.dataset.error_id); + this.setSpellSuggestionsFor(xNodeErr.textContent.trim(), "", xNodeErr.dataset.error_id); } } catch (e) { showError(e); } }, + + setTooltipColor: function (bBlue) { + // todo + }, + + hide () { + this.xTooltipArrow.style.display = "none"; + this.xTooltip.style.display = "none"; + }, _createSuggestion: function (sErrId, iSugg, sSugg) { let xNodeSugg = document.createElement("a"); xNodeSugg.id = "sugg" + sErrId + "-" + iSugg.toString(); xNodeSugg.className = "sugg"; @@ -214,11 +336,11 @@ setSpellSuggestionsFor: function (sWord, sSuggestions, sErrId) { // spell checking suggestions try { // console.log("setSuggestionsFor: " + sWord + " > " + sSuggestions + " // " + sErrId); - let xSuggBlock = document.getElementById("sc_sugg_block"); + let xSuggBlock = document.getElementById("grammalecte_tooltip_sugg_block"); xSuggBlock.textContent = ""; if (sSuggestions === "") { xSuggBlock.appendChild(document.createTextNode("Aucune.")); } else if (sSuggestions.startsWith("#")) { xSuggBlock.appendChild(document.createTextNode(sSuggestions)); @@ -233,86 +355,7 @@ } } catch (e) { showError(e); } - }, - - hideAllTooltips: function () { - document.getElementById("gc_tooltip").style.display = "none"; - document.getElementById("gc_rule_id").style.display = "none"; - document.getElementById("sc_tooltip").style.display = "none"; - document.getElementById("gc_tooltip_arrow").style.display = "none"; - document.getElementById("sc_tooltip_arrow").style.display = "none"; - }, - - addSummary: function () { - // todo - }, - - addMessage: function (sMessage) { - let xNode = createNode("div", {className: "grammalecte_gc_panel_message", textContent: sMessage}); - this._xContentNode.appendChild(xNode); - } -} - - - - - - - - - - - -function sendBackAndCheck (sCheckButtonId) { // check - startWaitIcon(); - let sIdParagr = sCheckButtonId.slice(5); - self.port.emit("modifyAndCheck", sIdParagr, getPurgedTextOfParagraph("paragr"+sIdParagr)); - stopWaitIcon(); -} - - - - - -function getPurgedTextOfParagraph (sNodeParagrId) { - let sText = document.getElementById(sNodeParagrId).textContent; - sText = sText.replace(/ /g, " ").replace(/</g, "<").replace(/>/g, ">").replace(/&/g, "&"); - return sText; -} - -function copyToClipboard () { - startWaitIcon(); - try { - let xClipboardButton = document.getElementById("clipboard_msg"); - xClipboardButton.textContent = "copie en cours…"; - let sText = ""; - for (let xNode of document.getElementById("errorlist").getElementsByClassName("paragraph")) { - sText += xNode.textContent + "\n"; - } - self.port.emit('copyToClipboard', sText); - xClipboardButton.textContent = "-> presse-papiers"; - window.setTimeout(function() { xClipboardButton.textContent = "∑"; } , 3000); - } - catch (e) { - console.log(e.lineNumber + ": " +e.message); - } - stopWaitIcon(); -} - -function startWaitIcon (sIdParagr=null) { - if (sIdParagr) { - document.getElementById(sIdParagr).disabled = true; - document.getElementById(sIdParagr).style.opacity = .3; - } - document.getElementById("waiticon").hidden = false; -} - -function stopWaitIcon (sIdParagr=null) { - if (sIdParagr) { - document.getElementById(sIdParagr).disabled = false; - document.getElementById(sIdParagr).style.opacity = 1; - } - document.getElementById("waiticon").hidden = true; + } } Index: gc_lang/fr/webext/content_scripts/lxg_content.js ================================================================== --- gc_lang/fr/webext/content_scripts/lxg_content.js +++ gc_lang/fr/webext/content_scripts/lxg_content.js @@ -6,11 +6,11 @@ _xContentNode: createNode("div", {id: "grammalecte_lxg_panel_content"}), _nCount: 0, - getNode: function () { + init: function () { return this._xContentNode; }, clear: function () { this._nCount = 0; 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 @@ -21,14 +21,15 @@ _createPanel (sTitle) { try { let xPanel = createNode("div", {id: this.sId, className: "grammalecte_panel"}); let xBar = createNode("div", {className: "grammalecte_panel_bar"}); + xBar.appendChild(this._createWaitIcon()); xBar.appendChild(this._createButtons()); let xTitle = createNode("div", {className: "grammalecte_panel_title"}); xTitle.appendChild(createLogo()); - xTitle.appendChild(createNode("div", {className: "grammalecte_panel_label", textContent: "Grammalecte · " + sTitle})); + xTitle.appendChild(createNode("div", {className: "grammalecte_panel_label", textContent: sTitle})); xBar.appendChild(xTitle); xPanel.appendChild(xBar); //xPanel.appendChild(createNode("div", {className: "grammalecte_empty_space_under_title_bar"})); xPanel.appendChild(this.xContentNode); return xPanel; @@ -35,13 +36,22 @@ } catch (e) { showError(e); } } + + _createWaitIcon () { + let xWaitIcon = createNode("div", {id: "grammalecte_wait_icon", className: "grammalecte_spinner"}); + xWaitIcon.appendChild(createNode("div", {id: "bounce1"})); + xWaitIcon.appendChild(createNode("div", {id: "bounce2"})); + return xWaitIcon; + } _createButtons () { let xButtonLine = createNode("div", {className: "grammalecte_panel_commands"}); + + 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")); @@ -110,10 +120,18 @@ logInnerHTML () { // for debugging console.log(this.xPanelNode.innerHTML); } + + startWaitIcon () { + document.getElementById("grammalecte_waiticon").hidden = false; + } + + stopWaitIcon () { + document.getElementById("grammalecte_waiticon").hidden = true; + } } /* Common functions Index: gc_lang/fr/xpi/data/gc_panel.js ================================================================== --- gc_lang/fr/xpi/data/gc_panel.js +++ gc_lang/fr/xpi/data/gc_panel.js @@ -199,11 +199,11 @@ function _tagParagraph (sParagraph, xParagraph, iParagraph, aSpellErr, aGrammErr) { try { if (aGrammErr.length === 0 && aSpellErr.length === 0) { xParagraph.textContent = sParagraph; - return + return; } aGrammErr.push(...aSpellErr); aGrammErr.sort(function (a, b) { if (a["nStart"] < b["nStart"]) return -1;