Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fork Sync: Update from parent repository #222

Closed
wants to merge 3 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions dist/firefox/updates.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@
"[email protected]": {
"updates": [
{
"version": "1.54.1.5",
"version": "1.54.1.6",
"browser_specific_settings": { "gecko": { "strict_min_version": "78.0" } },
"update_link": "https://github.com/gorhill/uBlock/releases/download/1.54.1b5/uBlock0_1.54.1b5.firefox.signed.xpi"
"update_link": "https://github.com/gorhill/uBlock/releases/download/1.54.1b6/uBlock0_1.54.1b6.firefox.signed.xpi"
}
]
}
Expand Down
2 changes: 1 addition & 1 deletion dist/version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
1.54.1.5
1.54.1.6
42 changes: 9 additions & 33 deletions src/js/dom-inspector.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,22 +25,19 @@
/******************************************************************************/

const svgRoot = document.querySelector('svg');
let inspectorContentPort;

const quit = ( ) => {
inspectorContentPort.postMessage({ what: 'quitInspector' });
const shutdown = ( ) => {
inspectorContentPort.close();
inspectorContentPort.onmessage = inspectorContentPort.onmessageerror = null;
inspectorContentPort = undefined;
loggerPort.postMessage({ what: 'quitInspector' });
loggerPort.close();
loggerPort.onmessage = loggerPort.onmessageerror = null;
loggerPort = undefined;
};

const onMessage = (msg, fromLogger) => {
const contentInspectorChannel = ev => {
const msg = ev.data || {};
switch ( msg.what ) {
case 'quitInspector': {
quit();
shutdown();
break;
}
case 'svgPaths': {
Expand All @@ -52,41 +49,20 @@ const onMessage = (msg, fromLogger) => {
break;
}
default:
if ( typeof fromLogger !== 'boolean' ) { return; }
if ( fromLogger ) {
inspectorContentPort.postMessage(msg);
} else {
loggerPort.postMessage(msg);
}
break;
}
};

// Wait for the content script to establish communication

let inspectorContentPort;

let loggerPort = new globalThis.BroadcastChannel('loggerInspector');
loggerPort.onmessage = ev => {
const msg = ev.data || {};
onMessage(msg, true);
};
loggerPort.onmessageerror = ( ) => {
quit();
};

globalThis.addEventListener('message', ev => {
const msg = ev.data || {};
if ( msg.what !== 'startInspector' ) { return; }
if ( Array.isArray(ev.ports) === false ) { return; }
if ( ev.ports.length === 0 ) { return; }
inspectorContentPort = ev.ports[0];
inspectorContentPort.onmessage = ev => {
const msg = ev.data || {};
onMessage(msg, false);
};
inspectorContentPort.onmessageerror = ( ) => {
quit();
};
inspectorContentPort.onmessage = contentInspectorChannel;
inspectorContentPort.onmessageerror = shutdown;
inspectorContentPort.postMessage({ what: 'startInspector' });
}, { once: true });

/******************************************************************************/
130 changes: 99 additions & 31 deletions src/js/logger-ui-inspector.js
Original file line number Diff line number Diff line change
Expand Up @@ -42,21 +42,97 @@ let inspectedURL = '';
let inspectedHostname = '';
let uidGenerator = 1;

/******************************************************************************/
/*******************************************************************************
*
* How it works:
*
* 1. The logger/inspector is enabled from the logger window
*
* 2. The inspector content script is injected in the root frame of the tab
* currently selected in the logger
*
* 3. The inspector content script asks the logger/inspector to establish
* a two-way communication channel
*
* 3. The inspector content script embed an inspector frame in the document
* being inspected and waits for the inspector frame to be fully loaded
*
* 4. The inspector content script sends a messaging port object to the
* embedded inspector frame for a two-way communication channel between
* the inspector frame and the inspector content script
*
* 5. The inspector content script sends dom information to the
* logger/inspector
*
* */

const contentInspectorChannel = (( ) => {
let bcChannel;
let toContentPort;

const start = ( ) => {
bcChannel = new globalThis.BroadcastChannel('contentInspectorChannel');
bcChannel.onmessage = ev => {
const msg = ev.data || {};
connect(msg.tabId, msg.frameId);
};
browser.webNavigation.onDOMContentLoaded.addListener(onContentLoaded);
};

const inspectorFramePort = new globalThis.BroadcastChannel('loggerInspector');
inspectorFramePort.onmessage = ev => {
const msg = ev.data || {};
if ( msg.what === 'domLayoutFull' ) {
inspectedURL = msg.url;
inspectedHostname = msg.hostname;
renderDOMFull(msg);
} else if ( msg.what === 'domLayoutIncremental' ) {
renderDOMIncremental(msg);
}
};
inspectorFramePort.onmessageerror = ( ) => {
};
const shutdown = ( ) => {
browser.webNavigation.onDOMContentLoaded.removeListener(onContentLoaded);
disconnect();
bcChannel.close();
bcChannel.onmessage = null;
bcChannel = undefined;
};

const connect = (tabId, frameId) => {
disconnect();
try {
toContentPort = browser.tabs.connect(tabId, { frameId });
toContentPort.onMessage.addListener(onContentMessage);
toContentPort.onDisconnect.addListener(onContentDisconnect);
} catch(_) {
}
};

const disconnect = ( ) => {
if ( toContentPort === undefined ) { return; }
toContentPort.onMessage.removeListener(onContentMessage);
toContentPort.onDisconnect.removeListener(onContentDisconnect);
toContentPort.disconnect();
toContentPort = undefined;
};

const send = msg => {
if ( toContentPort === undefined ) { return; }
toContentPort.postMessage(msg);
};

const onContentMessage = msg => {
if ( msg.what === 'domLayoutFull' ) {
inspectedURL = msg.url;
inspectedHostname = msg.hostname;
renderDOMFull(msg);
} else if ( msg.what === 'domLayoutIncremental' ) {
renderDOMIncremental(msg);
}
};

const onContentDisconnect = ( ) => {
disconnect();
};

const onContentLoaded = details => {
if ( details.tabId !== inspectedTabId ) { return; }
if ( details.frameId !== 0 ) { return; }
disconnect();
injectInspector();
};

return { start, disconnect, send, shutdown };
})();

/******************************************************************************/

Expand Down Expand Up @@ -345,15 +421,15 @@ const startDialog = (( ) => {
};

const showCommitted = function() {
inspectorFramePort.postMessage({
contentInspectorChannel.send({
what: 'showCommitted',
hide: hideSelectors.join(',\n'),
unhide: unhideSelectors.join(',\n')
});
};

const showInteractive = function() {
inspectorFramePort.postMessage({
contentInspectorChannel.send({
what: 'showInteractive',
hide: hideSelectors.join(',\n'),
unhide: unhideSelectors.join(',\n')
Expand Down Expand Up @@ -432,7 +508,7 @@ const onClicked = ev => {

// Toggle cosmetic filter
if ( dom.cl.has(target, 'filter') ) {
inspectorFramePort.postMessage({
contentInspectorChannel.send({
what: 'toggleFilter',
original: false,
target: dom.cl.toggle(target, 'off'),
Expand All @@ -448,7 +524,7 @@ const onClicked = ev => {
}
// Toggle node
else {
inspectorFramePort.postMessage({
contentInspectorChannel.send({
what: 'toggleNodes',
original: true,
target: dom.cl.toggle(target, 'off') === false,
Expand All @@ -468,7 +544,7 @@ const onMouseOver = (( ) => {
let mouseoverTarget = null;

const mouseoverTimer = vAPI.defer.create(( ) => {
inspectorFramePort.postMessage({
contentInspectorChannel.send({
what: 'highlightOne',
selector: selectorFromNode(mouseoverTarget),
nid: nidFromNode(mouseoverTarget),
Expand Down Expand Up @@ -517,7 +593,7 @@ const injectInspector = (( ) => {
/******************************************************************************/

const shutdownInspector = ( ) => {
inspectorFramePort.postMessage({ what: 'quitInspector' });
contentInspectorChannel.disconnect();
logger.removeAllChildren(domTree);
dom.cl.remove(inspector, 'vExpanded');
inspectedTabId = 0;
Expand All @@ -537,14 +613,6 @@ const onTabIdChanged = ( ) => {

/******************************************************************************/

const onDOMContentLoaded = details => {
if ( details.tabId !== inspectedTabId ) { return; }
if ( details.frameId !== 0 ) { return; }
injectInspector();
};

/******************************************************************************/

const toggleVCompactView = ( ) => {
const state = dom.cl.toggle(inspector, 'vExpanded');
const branches = qsa$('#domInspector li.branch');
Expand All @@ -561,7 +629,7 @@ const toggleHCompactView = ( ) => {

const revert = ( ) => {
dom.cl.remove('#domTree .off', 'off');
inspectorFramePort.postMessage({ what: 'resetToggledNodes' });
contentInspectorChannel.send({ what: 'resetToggledNodes' });
dom.cl.add(qs$(inspector, '.permatoolbar .revert'), 'disabled');
dom.cl.add(qs$(inspector, '.permatoolbar .commit'), 'disabled');
};
Expand All @@ -578,7 +646,7 @@ const toggleOn = ( ) => {
dom.on('#domInspector .hCompactToggler', 'click', toggleHCompactView);
dom.on('#domInspector .permatoolbar .revert', 'click', revert);
dom.on('#domInspector .permatoolbar .commit', 'click', startDialog);
browser.webNavigation.onDOMContentLoaded.addListener(onDOMContentLoaded);
contentInspectorChannel.start();
injectInspector();
};

Expand All @@ -596,7 +664,7 @@ const toggleOff = ( ) => {
dom.off('#domInspector .hCompactToggler', 'click', toggleHCompactView);
dom.off('#domInspector .permatoolbar .revert', 'click', revert);
dom.off('#domInspector .permatoolbar .commit', 'click', startDialog);
browser.webNavigation.onDOMContentLoaded.removeListener(onDOMContentLoaded);
contentInspectorChannel.shutdown();
inspectedTabId = 0;
};

Expand Down
6 changes: 6 additions & 0 deletions src/js/messaging.js
Original file line number Diff line number Diff line change
Expand Up @@ -1860,6 +1860,12 @@ const onMessage = (request, sender, callback) => {
let response;
switch ( request.what ) {
case 'getInspectorArgs':
const bc = new globalThis.BroadcastChannel('contentInspectorChannel');
bc.postMessage({
what: 'contentInspectorChannel',
tabId: sender.tabId || 0,
frameId: sender.frameId || 0,
});
response = {
inspectorURL: vAPI.getURL(
`/web_accessible_resources/dom-inspector.html?secret=${vAPI.warSecret.short()}`
Expand Down
Loading
Loading