Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 /* | 1 /* |
2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present eyeo GmbH |
4 * | 4 * |
5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
8 * | 8 * |
9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
12 * GNU General Public License for more details. | 12 * GNU General Public License for more details. |
13 * | 13 * |
14 * You should have received a copy of the GNU General Public License | 14 * You should have received a copy of the GNU General Public License |
15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
16 */ | 16 */ |
17 | 17 |
18 /** @module uninstall */ | 18 /** @module uninstall */ |
19 | 19 |
20 "use strict"; | 20 "use strict"; |
21 | 21 |
22 const info = require("../buildtools/info"); | 22 const info = require("../buildtools/info"); |
23 const subscriptionInit = require("./subscriptionInit.js"); | 23 const {isDataCorrupted} = require("./subscriptionInit.js"); |
kzar
2018/04/25 14:38:12
Nit: const {dataCorrupted} = require(...)?
Sebastian Noack
2018/04/25 14:46:23
At the time we import subscriptionInit.js, dataCor
kzar
2018/04/25 14:57:04
That's why I suggest making it a getter instead.
| |
24 const {Prefs} = require("./prefs"); | 24 const {Prefs} = require("./prefs"); |
25 const {Utils} = require("./utils"); | 25 const {Utils} = require("./utils"); |
26 | 26 |
27 let setUninstallURL = | 27 let setUninstallURL = |
28 /** | 28 /** |
29 * Sets (or updates) the URL that is openend when the extension is uninstalled. | 29 * Sets (or updates) the URL that is openend when the extension is uninstalled. |
30 * | 30 * |
31 * Must be called after prefs got initilized and a data corruption | 31 * Must be called after prefs got initialized and a data corruption |
kzar
2018/04/25 14:38:12
Nit: A couple typos 'initialized' and 'notificatio
Sebastian Noack
2018/04/25 14:46:23
Done.
| |
32 * if any was detected, as well when noification data change. | 32 * if any was detected, as well when notification data change. |
33 */ | 33 */ |
34 exports.setUninstallURL = () => | 34 exports.setUninstallURL = () => |
35 { | 35 { |
36 let search = []; | 36 let search = []; |
37 for (let key of ["addonName", "addonVersion", "application", | 37 for (let key of ["addonName", "addonVersion", "application", |
38 "applicationVersion", "platform", "platformVersion"]) | 38 "applicationVersion", "platform", "platformVersion"]) |
39 search.push(key + "=" + encodeURIComponent(info[key])); | 39 search.push(key + "=" + encodeURIComponent(info[key])); |
40 | 40 |
41 let downlCount = Prefs.notificationdata.downloadCount || 0; | 41 let downlCount = Prefs.notificationdata.downloadCount || 0; |
42 | 42 |
43 if (downlCount > 4) | 43 if (downlCount > 4) |
44 { | 44 { |
45 if (downlCount < 8) | 45 if (downlCount < 8) |
46 downlCount = "5-7"; | 46 downlCount = "5-7"; |
47 else if (downlCount < 30) | 47 else if (downlCount < 30) |
48 downlCount = "8-29"; | 48 downlCount = "8-29"; |
49 else if (downlCount < 90) | 49 else if (downlCount < 90) |
50 downlCount = "30-89"; | 50 downlCount = "30-89"; |
51 else if (downlCount < 180) | 51 else if (downlCount < 180) |
52 downlCount = "90-179"; | 52 downlCount = "90-179"; |
53 else | 53 else |
54 downlCount = "180+"; | 54 downlCount = "180+"; |
55 } | 55 } |
56 | 56 |
57 search.push("notificationDownloadCount=" + encodeURIComponent(downlCount)); | 57 search.push("notificationDownloadCount=" + encodeURIComponent(downlCount)); |
58 search.push("dataCorrupted=" + (subscriptionInit.dataCorrupted ? "1" : "0")); | 58 search.push("dataCorrupted=" + (isDataCorrupted() ? "1" : "0")); |
59 | 59 |
60 browser.runtime.setUninstallURL(Utils.getDocLink("uninstalled") + "&" + | 60 browser.runtime.setUninstallURL(Utils.getDocLink("uninstalled") + "&" + |
61 search.join("&")); | 61 search.join("&")); |
62 }; | 62 }; |
63 | 63 |
64 Prefs.on("notificationdata", setUninstallURL); | 64 Prefs.on("notificationdata", setUninstallURL); |
LEFT | RIGHT |