OLD | NEW |
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 |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 { | 96 { |
97 window.clearTimeout(activateClickHide.timeout); | 97 window.clearTimeout(activateClickHide.timeout); |
98 activateClickHide.timeout = null; | 98 activateClickHide.timeout = null; |
99 } | 99 } |
100 document.body.classList.remove("clickhide-active"); | 100 document.body.classList.remove("clickhide-active"); |
101 browser.tabs.sendMessage(tab.id, {type: "composer.content.finished"}); | 101 browser.tabs.sendMessage(tab.id, {type: "composer.content.finished"}); |
102 } | 102 } |
103 | 103 |
104 function reportIssue() | 104 function reportIssue() |
105 { | 105 { |
106 browser.tabs.create({ | 106 browser.tabs.captureVisibleTab( |
107 url: browser.runtime.getURL("/issue-reporter.html?" + tab.id) | 107 null, |
108 }).then(() => | 108 {format: "png"}, |
109 { | 109 screenshot => |
110 window.close(); | 110 { |
111 }); | 111 // in some obscure circumstance the screenshot is undefined |
| 112 // but asking again for it later on will work every time |
| 113 if (!screenshot) |
| 114 return setTimeout(reportIssue); |
| 115 |
| 116 // setup a listener to provide once tab url |
| 117 // and base64 screenshot data once asked |
| 118 browser.runtime.onMessage.addListener( |
| 119 function onMessage(event) |
| 120 { |
| 121 if (event.type == "issue-reporter") |
| 122 { |
| 123 browser.runtime.onMessage.removeListener(onMessage); |
| 124 return Promise.resolve({url: tab.url, screenshot}); |
| 125 } |
| 126 } |
| 127 ); |
| 128 |
| 129 browser.tabs.create({ |
| 130 active: true, |
| 131 url: browser.runtime.getURL("/issue-reporter.html?" + tab.id) |
| 132 }); |
| 133 } |
| 134 ); |
112 } | 135 } |
113 | 136 |
114 function toggleCollapse(event) | 137 function toggleCollapse(event) |
115 { | 138 { |
116 let collapser = event.currentTarget; | 139 let collapser = event.currentTarget; |
117 let collapsible = document.getElementById(collapser.dataset.collapsible); | 140 let collapsible = document.getElementById(collapser.dataset.collapsible); |
118 collapsible.classList.toggle("collapsed"); | 141 collapsible.classList.toggle("collapsed"); |
119 togglePref(collapser.dataset.option); | 142 togglePref(collapser.dataset.option); |
120 } | 143 } |
121 | 144 |
(...skipping 210 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
332 { | 355 { |
333 if (event.target.id == "notification-optout") | 356 if (event.target.id == "notification-optout") |
334 setPref("notifications_ignoredcategories", true); | 357 setPref("notifications_ignoredcategories", true); |
335 | 358 |
336 notificationElement.hidden = true; | 359 notificationElement.hidden = true; |
337 browser.runtime.sendMessage({type: "notifications.clicked"}); | 360 browser.runtime.sendMessage({type: "notifications.clicked"}); |
338 } | 361 } |
339 }, true); | 362 }, true); |
340 }); | 363 }); |
341 }); | 364 }); |
OLD | NEW |