From e6186f5f00a69717e4408b78ab4f4e899324ab5e Mon Sep 17 00:00:00 2001 From: dpilafian Date: Sun, 1 Oct 2023 00:46:51 -0700 Subject: [PATCH] Use undocumented event listener to update Blogger page --- src/css/blogger-tweaks/spec.html | 2 +- src/css/reset.less | 2 +- src/js/lib-x.ts | 16 ++++++---------- 3 files changed, 8 insertions(+), 12 deletions(-) diff --git a/src/css/blogger-tweaks/spec.html b/src/css/blogger-tweaks/spec.html index 48cdedb..30d461b 100644 --- a/src/css/blogger-tweaks/spec.html +++ b/src/css/blogger-tweaks/spec.html @@ -36,7 +36,7 @@ - + diff --git a/src/css/reset.less b/src/css/reset.less index b375c2d..a5ee36e 100644 --- a/src/css/reset.less +++ b/src/css/reset.less @@ -156,7 +156,7 @@ ul.simple-text li { font-size: 1rem; text-indent: 0px; padding: 0px; } // // or // figure.video-container, diff --git a/src/js/lib-x.ts b/src/js/lib-x.ts index 4e5b735..e1c1640 100644 --- a/src/js/lib-x.ts +++ b/src/js/lib-x.ts @@ -35,6 +35,8 @@ export type NavigatorUAData = { readonly platform: string; //examples: "macOS", "Windows" }; export type LibX = typeof libX; +type Blogger = { ui: () => { addListener: (type: string, listener: () => void) => void, Lc: { wb: string[] } } }; +declare global { var blogger: Blogger } //eslint-disable-line no-var declare global { var dataLayer: unknown[] } //eslint-disable-line no-var declare global { var hljsEnhance: { setup: () => void } } //eslint-disable-line no-var declare global { var libX: LibX } //eslint-disable-line no-var @@ -979,21 +981,15 @@ const libXExtra = { // Setup Blogger's Dynamic Views (sidebar) console.log('Setup for:', websiteUrl); const onArticleLoad = () => { + //console.log('Event types:', Object.keys(globalThis.blogger.ui().Lc.wb)); const title = libX.dom.select('h1.entry-title')!.textContent!.trim(); - console.log('Article: %c' + title, 'font-weight: bold; color: purple;'); + console.log('Article: %c' + title, 'font-weight: bold; color: turquoise;'); libX.dom.select('#header >.header-bar h3')!.dataset.href = websiteUrl; libX.ui.normalize(); globalThis.hljsEnhance.setup(); }; - const ready = () => { - console.log(Date.now(), 'loading...'); - if (globalThis.document.querySelector('#header h1')) //takes about a second or so for page to load - onArticleLoad(); - else - globalThis.setTimeout(ready, 500); - }; - ready(); - globalThis.setTimeout(libX.ui.normalize, 2000); //hack to workaround Blogger js errors + const delayed = () => globalThis.setTimeout(onArticleLoad, 2000); //hack to let page load + globalThis.blogger.ui().addListener('updated', delayed); }, gTags(scriptTag: HTMLScriptElement): void { // Google Tracking