/
popup.js
110 lines (89 loc) · 3.38 KB
/
popup.js
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
This file is part of Talkie -- text-to-speech browser extension button.
<https://github.com/joelpurra/talkie>
Copyright (c) 2016, 2017 Joel Purra <https://joelpurra.com/>
Talkie is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Talkie is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Talkie. If not, see <https://www.gnu.org/licenses/>.
*/
import {
promiseTry,
} from "../shared/promise";
import {
getBackgroundPage,
} from "../shared/tabs";
import {
knownEvents,
} from "../shared/events";
import {
getStoredValue,
} from "../shared/storage";
import {
eventToPromise,
startFrontend,
stopFrontend,
} from "../frontend/shared-frontend";
import DualLogger from "../frontend/dual-log";
const dualLogger = new DualLogger("popup.js");
const loadOptionsAndApply = () => promiseTry(
() => {
const hideDonationsOptionId = "options-popup-donate-buttons-hide";
return Promise.resolve()
.then(() => getStoredValue(hideDonationsOptionId))
.then((hideDonations) => {
hideDonations = hideDonations === true;
if (hideDonations) {
const elementsToHide = []
.concat(Array.from(document.getElementsByTagName("footer")))
.concat(Array.from(document.getElementsByTagName("hr")));
elementsToHide.forEach((element) => {
element.style.display = "none";
});
}
return undefined;
});
}
);
const passClickToBackground = (background) => promiseTry(
() => {
try {
dualLogger.dualLog("Start", "passClickToBackground");
background.iconClick();
dualLogger.dualLog("Done", "passClickToBackground");
} catch (error) {
dualLogger.dualLogError("Error", "passClickToBackground", error);
throw error;
}
}
);
const updateProgress = (data) => {
const progressBar = document.getElementById("progress");
progressBar.max = data.max - data.min;
progressBar.value = data.current;
};
const start = () => promiseTry(
() => {
return Promise.resolve()
.then(() => startFrontend())
.then(() => loadOptionsAndApply())
.then(() => getBackgroundPage())
.then((background) => background.broadcaster.registerListeningAction(knownEvents.updateProgress, (/* eslint-disable no-unused-vars*/actionName/* eslint-enable no-unused-vars*/, actionData) => updateProgress(actionData)))
.then(() => getBackgroundPage())
.then((background) => passClickToBackground(background));
}
);
const stop = () => promiseTry(
() => {
return Promise.resolve()
.then(() => stopFrontend());
}
);
document.addEventListener("DOMContentLoaded", eventToPromise.bind(null, start));
window.addEventListener("unload", eventToPromise.bind(null, stop));