Overview
| Comment: | [fx] WebExt: remove wrapper around textareas, add button and menu |
|---|---|
| Downloads: | Tarball | ZIP archive | SQL archive |
| Timelines: | family | ancestors | descendants | both | trunk | fx |
| Files: | files | file ages | folders |
| SHA3-256: |
3cd8dde332fb086db06ee3a453d2b498 |
| User & Date: | olr on 2017-09-06 17:40:22 |
| Other Links: | manifest | tags |
Context
|
2017-09-06
| ||
| 19:15 | [fx] WebExt: help update check-in: aa0b62f525 user: olr tags: trunk, fx | |
| 17:40 | [fx] WebExt: remove wrapper around textareas, add button and menu check-in: 3cd8dde332 user: olr tags: trunk, fx | |
| 09:10 | [fx] WebExt: run content scripts at document_end (before the page finishes to load all external resources) check-in: 24c1fb45bc user: olr tags: trunk, fx | |
Changes
Modified gc_lang/fr/webext/content_scripts/init.js from [79f4d2add2] to [ccdc2aeb0d].
| ︙ | ︙ | |||
41 42 43 44 45 46 47 |
oElem.appendChild(img);
});
}
*/
const oGrammalecte = {
| | | | | | | 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
oElem.appendChild(img);
});
}
*/
const oGrammalecte = {
nMenu: 0,
lMenu: [],
oTFPanel: null,
oLxgPanel: null,
oGCPanel: null,
createMenus: function () {
let lNode = document.getElementsByTagName("textarea");
for (let xNode of lNode) {
this.lMenu.push(new GrammalecteMenu(this.nMenu, xNode));
this.nMenu += 1;
}
},
createTFPanel: function () {
if (this.oTFPanel === null) {
this.oTFPanel = new GrammalecteTextFormatter("grammalecte_tf_panel", "Formateur de texte", 800, 620, false);
//this.oTFPanel.logInnerHTML();
|
| ︙ | ︙ | |||
130 131 132 133 134 135 136 |
}
});
/*
Start
*/
| | | 130 131 132 133 134 135 136 137 |
}
});
/*
Start
*/
oGrammalecte.createMenus();
|
Added gc_lang/fr/webext/content_scripts/menu.css version [6770b05fc9].
> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 |
/*
CSS
Menu for Grammalecte
*/
.grammalecte_menu_main_button {
position: absolute;
margin: -17px 0 0 -16px;
border-radius: 16px;
background-color: hsla(210, 50%, 50%, .5);
background-image: url('');
background-repeat: no-repeat;
width: 32px;
height: 32px;
cursor: pointer;
z-index: 100000000;
}
.grammalecte_menu {
display: none;
position: absolute;
margin-left: -10px;
border-radius: 5px;
border: 3px solid hsl(210, 50%, 30%);
box-shadow: 0px 0px 2px hsla(210, 10%, 10%, .5);
font-family: "Trebuchet MS", "Liberation Sans", sans-serif;
}
.grammalecte_menu_item {
padding: 3px 10px;
background-color: hsl(210, 50%, 50%);
font-size: 14px;
color: hsl(210, 50%, 92%);
cursor: pointer;
}
.grammalecte_menu_item:hover {
background-color: hsl(210, 60%, 60%);
color: hsl(210, 60%, 100%);
}
.grammalecte_menu_item_block {
padding: 3px 10px;
background-color: hsl(210, 50%, 50%);
font-size: 14px;
color: hsl(210, 50%, 92%);
border-top: 1px solid hsl(210, 50%, 30%);;
}
.grammalecte_menu_button {
display: inline-block;
padding: 0 5px;
margin-left: 10px;
border-radius: 2px;
background-color: hsl(210, 50%, 55%);
font-size: 12px;
line-height: 1.6;
text-align: center;
cursor: pointer;
}
.grammalecte_menu_button:hover {
background-color: hsl(210, 60%, 60%);
}
.grammalecte_menu_header {
padding: 2px 10px;
background-color: hsl(210, 50%, 30%);
font-size: 12px;
font-variant-caps: small-caps;
color: hsl(210, 50%, 90%);
text-shadow: 0px 0px 2px hsla(210, 10%, 10%, .9);
text-align: center;
}
|
Added gc_lang/fr/webext/content_scripts/menu.js version [de706e9682].
> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 |
// JavaScript
"use strict";
class GrammalecteMenu {
constructor (nMenu, xTextArea) {
this.sMenuId = "grammalecte_menu" + nMenu;
let xButton = createNode("div", {className: "grammalecte_menu_main_button"});
xButton.onclick = () => { this.switchMenu(); };
let xMenu = this._createMenu(xTextArea);
this._insertAfter(xButton, xTextArea);
this._insertAfter(xMenu, xTextArea);
}
_insertAfter (xNewNode, xReferenceNode) {
xReferenceNode.parentNode.insertBefore(xNewNode, xReferenceNode.nextSibling);
}
_createMenu (xTextArea) {
try {
let xMenu = createNode("div", {id: this.sMenuId, className: "grammalecte_menu"});
// Text formatter
let xTFButton = createNode("div", {className: "grammalecte_menu_item", textContent: "Formateur de texte"});
xTFButton.onclick = () => {
this.switchMenu();
oGrammalecte.createTFPanel();
oGrammalecte.oTFPanel.start(xTextArea);
oGrammalecte.oTFPanel.show();
};
// lexicographe
let xLxgButton = createNode("div", {className: "grammalecte_menu_item", textContent: "Lexicographe"});
xLxgButton.onclick = () => {
this.switchMenu();
oGrammalecte.createLxgPanel();
oGrammalecte.oLxgPanel.clear();
oGrammalecte.oLxgPanel.show();
oGrammalecte.oLxgPanel.startWaitIcon();
xGrammalectePort.postMessage({
sCommand: "getListOfTokens",
dParam: {sText: xTextArea.value},
dInfo: {sTextAreaId: xTextArea.id}
});
};
// Grammar checker
let xGCButton = createNode("div", {className: "grammalecte_menu_item", textContent: "Correction grammaticale"});
xGCButton.onclick = () => {
this.switchMenu();
oGrammalecte.createGCPanel();
oGrammalecte.oGCPanel.start(xTextArea);
oGrammalecte.oGCPanel.show();
oGrammalecte.oGCPanel.startWaitIcon();
xGrammalectePort.postMessage({
sCommand: "parseAndSpellcheck",
dParam: {sText: xTextArea.value, sCountry: "FR", bDebug: false, bContext: false},
dInfo: {sTextAreaId: xTextArea.id}
});
};
// Conjugation tool
let xConjButton = createNode("div", {className: "grammalecte_menu_item_block", textContent: "Conjugueur"});
let xConjButtonTab = createNode("div", {className: "grammalecte_menu_button", textContent: "Onglet"});
xConjButtonTab.onclick = () => {
this.switchMenu();
xGrammalectePort.postMessage({sCommand: "openConjugueurTab", dParam: null, dInfo: null});
};
let xConjButtonWin = createNode("div", {className: "grammalecte_menu_button", textContent: "Fenêtre"});
xConjButtonWin.onclick = () => {
this.switchMenu();
xGrammalectePort.postMessage({sCommand: "openConjugueurWindow", dParam: null, dInfo: null});
};
xConjButton.appendChild(xConjButtonTab);
xConjButton.appendChild(xConjButtonWin);
// Create
xMenu.appendChild(createNode("div", {className: "grammalecte_menu_header", textContent: "Grammalecte"}));
xMenu.appendChild(xTFButton);
xMenu.appendChild(xLxgButton);
xMenu.appendChild(xGCButton);
xMenu.appendChild(xConjButton);
//xMenu.appendChild(createNode("img", {scr: browser.extension.getURL("img/logo-16.png")}));
// can’t work, due to content-script policy: https://bugzilla.mozilla.org/show_bug.cgi?id=1267027
xMenu.appendChild(createNode("div", {className: "grammalecte_menu_header"}));
return xMenu;
}
catch (e) {
showError(e);
}
}
switchMenu () {
let xMenu = document.getElementById(this.sMenuId);
xMenu.style.display = (xMenu.style.display == "block") ? "none" : "block";
}
}
|
Deleted gc_lang/fr/webext/content_scripts/wrapper.css version [bbf425edb7].
|
| < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < |
Deleted gc_lang/fr/webext/content_scripts/wrapper.js version [41723fc48c].
|
| < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < < |
Modified gc_lang/fr/webext/manifest.json from [f6f86f5cfc] to [33a68fe1cd].
| ︙ | ︙ | |||
40 41 42 43 44 45 46 |
{
"matches": ["<all_urls>"],
"css": [
"content_scripts/panel.css",
"content_scripts/panel_tf.css",
"content_scripts/panel_gc.css",
"content_scripts/panel_lxg.css",
| | | | 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
{
"matches": ["<all_urls>"],
"css": [
"content_scripts/panel.css",
"content_scripts/panel_tf.css",
"content_scripts/panel_gc.css",
"content_scripts/panel_lxg.css",
"content_scripts/menu.css",
"3rd/font-awesome-4.7.0/css/font-awesome.min.css"
],
"js": [
"content_scripts/panel.js",
"grammalecte/fr/textformatter.js",
"content_scripts/panel_tf.js",
"content_scripts/panel_gc.js",
"content_scripts/panel_lxg.js",
"content_scripts/menu.js",
"content_scripts/init.js"
],
"run_at": "document_end"
}
],
"commands": {
"conjugueur_tab": {
|
| ︙ | ︙ |