From 6d8c26fe0926bcf796964dcf0777ca09757c2d55 Mon Sep 17 00:00:00 2001 From: mi-yo Date: Wed, 15 Apr 2020 23:02:07 +0900 Subject: [PATCH 1/4] Adding manifest.json. (Merge pull request #8 from whistler-mb) --- build.sh | 4 ++-- manifest.json | 22 ++++++++++++++++++++++ 2 files changed, 24 insertions(+), 2 deletions(-) create mode 100644 manifest.json diff --git a/build.sh b/build.sh index 81a9cfa..1683b62 100644 --- a/build.sh +++ b/build.sh @@ -1,4 +1,4 @@ -#!bin/sh +#!/bin/sh VERSION=`grep em:version install.rdf | tr -d "[:space:]/"` -zip -r subject_cleaner-$VERSION-tb.xpi content defaults locale chrome.manifest install.rdf +zip -r subject_cleaner-$VERSION-tb.xpi content defaults locale chrome.manifest install.rdf manifest.json diff --git a/manifest.json b/manifest.json new file mode 100644 index 0000000..6c2e8e1 --- /dev/null +++ b/manifest.json @@ -0,0 +1,22 @@ +{ + "manifest_version": 2, + "name": "Subject-Cleaner", + "description": "Remove extra strings from the subject while composing the message on Thunderbird.", + "version": "1.4.1", + "author": "mi-yo", + "homepage_url": "https://github.com/mi-yo/thunderbird-subjectcleaner", + "legacy": true, + "applications": { + "gecko": { + "id": "subjectcleaner@mozilla.extensions", + "strict_min_version": "68.0" + } + }, + + "legacy": { + "options": { + "page": "chrome://subjectcleaner/content/setting.xul", + "open_in_tab": false + } + } +} From c85f7aebc012ee4b882a8aa84a151b74387d720a Mon Sep 17 00:00:00 2001 From: mi-yo Date: Sun, 26 Apr 2020 12:40:39 +0900 Subject: [PATCH 2/4] Fix compatibility issue with Thunderbird 60 and 68 with refactoring. --- content/options.css | 72 +++++++++++ content/options.js | 212 ++++++++++++++++++++++++++++++++ content/options.xul | 72 +++++++++++ content/prefutil.js | 105 +--------------- content/setting.js | 68 +++------- content/setting.xul | 21 ++-- content/settingadd.js | 21 ---- install.rdf | 6 +- locale/en-US/subjectcleaner.dtd | 25 ++-- locale/ja-JP/subjectcleaner.dtd | 1 + manifest.json | 38 +++--- 11 files changed, 426 insertions(+), 215 deletions(-) create mode 100644 content/options.css create mode 100644 content/options.js create mode 100644 content/options.xul diff --git a/content/options.css b/content/options.css new file mode 100644 index 0000000..ae73619 --- /dev/null +++ b/content/options.css @@ -0,0 +1,72 @@ +html { + background-color: #f9f9fa; +} + +label.header { + margin: 15px; +} + +label.group { + font-weight: bold; +} + +tree { + width: 800px; + height: 204px; +} + +treecol { + color: #000 !important; + border-inline-start-style: none !important; +} + +treecol.right { + text-align: right; +} + +treecol.noheader label { + opacity: 0; +} + +treechildren::-moz-tree-row { + background-color: #fff; +} + +treechildren::-moz-tree-cell { + padding: 0px 10px; +} + +treechildren::-moz-tree-cell-text { + color: #000; +} + +treechildren::-moz-tree-cell-text(inputtext,hover) { + margin-top: 2px; + border-bottom: 2px solid #2292d0; +} + +treechildren::-moz-tree-checkbox(checked) { + list-style-image: url("chrome://global/skin/icons/check.svg"); + -moz-context-properties: fill, stroke; + fill: #2292d0; +} + +treechildren::-moz-tree-checkbox(checked,delete) { + list-style-image: url("chrome://messenger/skin/icons/delete.svg"); + -moz-context-properties: fill, stroke; + fill: #2292d0; +} + +checkbox { + margin: 2px 5px !important; +} + +textbox.testbox { + width: 800px; + margin: 5px; +} + +textbox.testbox.result { + color: #2292d0 !important; + opacity: 1; +} diff --git a/content/options.js b/content/options.js new file mode 100644 index 0000000..d4b74f4 --- /dev/null +++ b/content/options.js @@ -0,0 +1,212 @@ +if("undefined" == typeof(SubjectCleanerOptions)){ + var SubjectCleanerOptions = { + COLINDEX_NO : 0, + COLINDEX_REMOVAL_STRING : 1, + COLINDEX_CASE_SENSITIVE : 2, + COLINDEX_REGULAR_EXPRESSION : 3, + COLINDEX_DELETE : 4, + + getRemovalListTree : function(){ + return document.getElementById("removalListTree"); + }, + + startup : function(){ + let tree = SubjectCleanerOptions.getRemovalListTree(); + tree.isEditing = function(){ + return this.editingRow !== -1 && this.editingColumn !== null; + } + // ignore empty removal string + tree.view.setCellText = (function(row, col, value){ + let context = tree.view; + let baseFunc = tree.view.setCellText; + return function(row, col, value){ + // for Escape key at new treeItem + if(tree.view.rowCount <= row){ + return; + } + if(value === ""){ + let prevValue = context.getCellText(row, col); + if(prevValue === ""){ + SubjectCleanerOptions.deleteTreeItem(tree, row); + } + }else{ + baseFunc.call(context, row, col, value); + tree.view.selection.select(row); + } + }; + })(); + + tree.addEventListener("click", SubjectCleanerOptions.treeClick, true); + tree.addEventListener("keydown", SubjectCleanerOptions.treeKeyDown, true); + + document.getElementById("add").addEventListener("command", SubjectCleanerOptions.add, true); + document.getElementById("autoRemove").addEventListener("CheckboxStateChange", SubjectCleanerOptions.setAutoFocusStatus, true); + document.getElementById("test").addEventListener("command", SubjectCleanerOptions.test, true); + document.getElementById("default").addEventListener("command", SubjectCleanerOptions.default, true); + document.getElementById("apply").addEventListener("command", SubjectCleanerOptions.apply, true); + + SubjectCleanerOptions.fill( + SubjectCleanerPrefUtil.getRemovalList(), + SubjectCleanerPrefUtil.isAutoRemove(), + SubjectCleanerPrefUtil.isAutoFocus()); + }, + + treeClick : function(event){ + if(event.target.localName === "treechildren"){ + let tree = SubjectCleanerOptions.getRemovalListTree(); +//tb60? +// let row = {}, col = {}, part = {}; +// tree.getCellAt(event.clientX, event.clientY, row, col, part); + let treeCellInfo = tree.getCellAt(event.clientX, event.clientY); + if(treeCellInfo.row >= 0){ + switch(treeCellInfo.col.index){ + case SubjectCleanerOptions.COLINDEX_REMOVAL_STRING: + tree.startEditing(treeCellInfo.row, treeCellInfo.col); + break; + case SubjectCleanerOptions.COLINDEX_DELETE: + SubjectCleanerOptions.deleteTreeItem(tree, treeCellInfo.row); + break; + default: + break; + } + } + } + }, + + treeKeyDown : function(event){ + // ignore empty removal string when Escape key down + if(event.key === "Escape"){ + let tree = SubjectCleanerOptions.getRemovalListTree(); + if(tree.isEditing() && tree.view.getCellText(tree.editingRow, tree.editingColumn) === ""){ + SubjectCleanerOptions.deleteTreeItem(tree, tree.editingRow); + } + } + }, + + getCurrentRemovalList : function(){ + let removalList = new Array(); + let tree = SubjectCleanerOptions.getRemovalListTree(); + for(let i=0; i=0; i--){ + SubjectCleanerOptions.deleteTreeItem(tree, i); + } + + for(let i=0; i + + + + + + + +