mirror of
				https://github.com/notion-enhancer/notion-enhancer.git
				synced 2025-10-26 11:48:08 +11:00 
			
		
		
		
	prevent topbar collapse, api.electron, treat menu as hideable window
This commit is contained in:
		
							parent
							
								
									ec91fb6bf0
								
							
						
					
					
						commit
						d5a38c80ea
					
				| @ -32,11 +32,11 @@ export const createButton = async ({ web, components }, db) => { | |||||||
| 
 | 
 | ||||||
|   $pin.addEventListener('click', () => { |   $pin.addEventListener('click', () => { | ||||||
|     $pin.replaceWith($unpin); |     $pin.replaceWith($unpin); | ||||||
|     __enhancerElectronApi.browser.setAlwaysOnTop(true); |     electron.browser.setAlwaysOnTop(true); | ||||||
|   }); |   }); | ||||||
|   $unpin.addEventListener('click', () => { |   $unpin.addEventListener('click', () => { | ||||||
|     $unpin.replaceWith($pin); |     $unpin.replaceWith($pin); | ||||||
|     __enhancerElectronApi.browser.setAlwaysOnTop(false); |     electron.browser.setAlwaysOnTop(false); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   return $button; |   return $button; | ||||||
|  | |||||||
| @ -9,6 +9,7 @@ | |||||||
|   display: block; |   display: block; | ||||||
|   -webkit-app-region: drag; |   -webkit-app-region: drag; | ||||||
|   background: var(--theme--bg_secondary); |   background: var(--theme--bg_secondary); | ||||||
|  |   height: var(--integrated_titlebar--dragarea-height); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .integrated_titlebar--buttons { | .integrated_titlebar--buttons { | ||||||
| @ -56,3 +57,17 @@ | |||||||
|   background: var(--theme--accent_red); |   background: var(--theme--accent_red); | ||||||
|   color: var(--theme--accent_red-text); |   color: var(--theme--accent_red-text); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .notion-update-sidebar [style*='margin-top: 45px;'] { | ||||||
|  |   margin-top: calc(45px + var(--integrated_titlebar--dragarea-height, 0px)) !important; | ||||||
|  | } | ||||||
|  | .notion-topbar { | ||||||
|  |   height: calc(45px + var(--integrated_titlebar--dragarea-height, 0px)) !important; | ||||||
|  | } | ||||||
|  | .notion-frame { | ||||||
|  |   height: calc(100vh - 45px - var(--integrated_titlebar--dragarea-height, 0px)) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | body > .body-container { | ||||||
|  |   height: calc(100% - var(--integrated_titlebar--dragarea-height, 0px)) !important; | ||||||
|  | } | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
| 
 | 
 | ||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| export const createWindowButtons = async ({ web, components }, db) => { | export const createWindowButtons = async ({ electron, web, components }, db) => { | ||||||
|   let minimizeIcon = (await db.get(['minimize_icon'])) || (await components.feather('minus')), |   let minimizeIcon = (await db.get(['minimize_icon'])) || (await components.feather('minus')), | ||||||
|     maximizeIcon = (await db.get(['maximize_icon'])) || (await components.feather('maximize')), |     maximizeIcon = (await db.get(['maximize_icon'])) || (await components.feather('maximize')), | ||||||
|     unmaximizeIcon = |     unmaximizeIcon = | ||||||
| @ -48,21 +48,21 @@ export const createWindowButtons = async ({ web, components }, db) => { | |||||||
|       ${closeIcon} |       ${closeIcon} | ||||||
|     </button>`; |     </button>`; | ||||||
| 
 | 
 | ||||||
|   $minimize.addEventListener('click', () => __enhancerElectronApi.browser.minimize()); |   $minimize.addEventListener('click', () => electron.browser.minimize()); | ||||||
|   $maximize.addEventListener('click', () => __enhancerElectronApi.browser.maximize()); |   $maximize.addEventListener('click', () => electron.browser.maximize()); | ||||||
|   $unmaximize.addEventListener('click', () => __enhancerElectronApi.browser.unmaximize()); |   $unmaximize.addEventListener('click', () => electron.browser.unmaximize()); | ||||||
|   $close.addEventListener('click', () => __enhancerElectronApi.browser.close()); |   $close.addEventListener('click', () => electron.browser.close()); | ||||||
|   __enhancerElectronApi.browser.on('maximize', () => { |   electron.browser.on('maximize', () => { | ||||||
|     $maximize.replaceWith($unmaximize); |     $maximize.replaceWith($unmaximize); | ||||||
|   }); |   }); | ||||||
|   __enhancerElectronApi.browser.on('unmaximize', () => { |   electron.browser.on('unmaximize', () => { | ||||||
|     $unmaximize.replaceWith($maximize); |     $unmaximize.replaceWith($maximize); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   web.render( |   web.render( | ||||||
|     $windowButtons, |     $windowButtons, | ||||||
|     $minimize, |     $minimize, | ||||||
|     __enhancerElectronApi.browser.isMaximized() ? $unmaximize : $maximize, |     electron.browser.isMaximized() ? $unmaximize : $maximize, | ||||||
|     $close |     $close | ||||||
|   ); |   ); | ||||||
|   return $windowButtons; |   return $windowButtons; | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ | |||||||
| import { createWindowButtons } from './buttons.mjs'; | import { createWindowButtons } from './buttons.mjs'; | ||||||
| 
 | 
 | ||||||
| export default async function (api, db) { | export default async function (api, db) { | ||||||
|   const { web } = api, |   const { web, electron } = api, | ||||||
|     tilingMode = await db.get(['tiling']), |     tilingMode = await db.get(['tiling']), | ||||||
|     dragareaHeight = await db.get(['dragarea_height']), |     dragareaHeight = await db.get(['dragarea_height']), | ||||||
|     sidebarSelector = '.notion-sidebar', |     sidebarSelector = '.notion-sidebar', | ||||||
| @ -32,20 +32,23 @@ export default async function (api, db) { | |||||||
|           : '0px'; |           : '0px'; | ||||||
|     if (newSidebarWidth !== sidebarWidth) { |     if (newSidebarWidth !== sidebarWidth) { | ||||||
|       sidebarWidth = newSidebarWidth; |       sidebarWidth = newSidebarWidth; | ||||||
|       __enhancerElectronApi.sendMessageToHost('sidebar-width', sidebarWidth); |       electron.sendMessageToHost('sidebar-width', sidebarWidth); | ||||||
|     } |     } | ||||||
|     if (newPanelWidth !== panelWidth) { |     if (newPanelWidth !== panelWidth) { | ||||||
|       panelWidth = newPanelWidth; |       panelWidth = newPanelWidth; | ||||||
|       __enhancerElectronApi.sendMessageToHost('panel-width', panelWidth); |       electron.sendMessageToHost('panel-width', panelWidth); | ||||||
|     } |     } | ||||||
|   }; |   }; | ||||||
|   web.addDocumentObserver(updateDragareaOffsets); |   web.addDocumentObserver(updateDragareaOffsets); | ||||||
| 
 | 
 | ||||||
|   await web.whenReady([topbarSelector, topbarActionsSelector]); |   await web.whenReady([topbarSelector, topbarActionsSelector]); | ||||||
|   const $topbar = document.querySelector(topbarSelector), |   const $topbar = document.querySelector(topbarSelector), | ||||||
|     $dragarea = web.html`<div class="integrated_titlebar--dragarea" style="height:${dragareaHeight}px"></div>`; |     $dragarea = web.html`<div class="integrated_titlebar--dragarea"></div>`; | ||||||
|   $topbar.style.height = `${45 + dragareaHeight}px`; |  | ||||||
|   $topbar.prepend($dragarea); |   $topbar.prepend($dragarea); | ||||||
|  |   document.documentElement.style.setProperty( | ||||||
|  |     '--integrated_titlebar--dragarea-height', | ||||||
|  |     dragareaHeight + 'px' | ||||||
|  |   ); | ||||||
| 
 | 
 | ||||||
|   const $topbarActions = document.querySelector(topbarActionsSelector), |   const $topbarActions = document.querySelector(topbarActionsSelector), | ||||||
|     $windowButtons = await createWindowButtons(api, db); |     $windowButtons = await createWindowButtons(api, db); | ||||||
|  | |||||||
| @ -12,15 +12,16 @@ export default async function (api, db) { | |||||||
|   const { web } = api, |   const { web } = api, | ||||||
|     tilingMode = await db.get(['tiling']), |     tilingMode = await db.get(['tiling']), | ||||||
|     dragareaHeight = await db.get(['dragarea_height']), |     dragareaHeight = await db.get(['dragarea_height']), | ||||||
|     bodyContainerSelector = '.body-container', |  | ||||||
|     sidebarSelector = '.sidebar'; |     sidebarSelector = '.sidebar'; | ||||||
|   if (tilingMode) return; |   if (tilingMode) return; | ||||||
| 
 | 
 | ||||||
|   await web.whenReady([bodyContainerSelector, sidebarSelector]); |   await web.whenReady([sidebarSelector]); | ||||||
|   const $bodyContainer = document.querySelector(bodyContainerSelector), |   const $dragarea = web.html`<div class="integrated_titlebar--dragarea"></div>`; | ||||||
|     $dragarea = web.html`<div class="integrated_titlebar--dragarea" style="height:${dragareaHeight}px"></div>`; |  | ||||||
|   document.body.prepend($dragarea); |   document.body.prepend($dragarea); | ||||||
|   $bodyContainer.style.height = `calc(100% - ${dragareaHeight}px)`; |   document.documentElement.style.setProperty( | ||||||
|  |     '--integrated_titlebar--dragarea-height', | ||||||
|  |     dragareaHeight + 'px' | ||||||
|  |   ); | ||||||
| 
 | 
 | ||||||
|   const $sidebar = document.querySelector(sidebarSelector), |   const $sidebar = document.querySelector(sidebarSelector), | ||||||
|     $windowButtons = await createWindowButtons(api, db); |     $windowButtons = await createWindowButtons(api, db); | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ import * as router from './router.mjs'; | |||||||
| import './styles.mjs'; | import './styles.mjs'; | ||||||
| 
 | 
 | ||||||
| (async () => { | (async () => { | ||||||
|   const { env, fs, storage, registry, web, components } = api; |   const { env, fs, storage, electron, registry, web, components } = api; | ||||||
| 
 | 
 | ||||||
|   for (const mod of await registry.list((mod) => registry.enabled(mod.id))) { |   for (const mod of await registry.list((mod) => registry.enabled(mod.id))) { | ||||||
|     for (const sheet of mod.css?.menu || []) { |     for (const sheet of mod.css?.menu || []) { | ||||||
| @ -28,11 +28,14 @@ import './styles.mjs'; | |||||||
|   if (errors.length) { |   if (errors.length) { | ||||||
|     console.log('[notion-enhancer] registry errors:'); |     console.log('[notion-enhancer] registry errors:'); | ||||||
|     console.table(errors); |     console.table(errors); | ||||||
|     notifications.add({ |     const $errNotification = await notifications.add({ | ||||||
|       icon: 'alert-circle', |       icon: 'alert-circle', | ||||||
|       message: 'Failed to load mods (check console).', |       message: 'Failed to load mods (check console).', | ||||||
|       color: 'red', |       color: 'red', | ||||||
|     }); |     }); | ||||||
|  |     if (['win32', 'linux', 'darwin'].includes(env.name)) { | ||||||
|  |       $errNotification.addEventListener('click', () => electron.browser.openDevTools()); | ||||||
|  |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const db = await registry.db('a6621988-551d-495a-97d8-3c568bca2e9e'), |   const db = await registry.db('a6621988-551d-495a-97d8-3c568bca2e9e'), | ||||||
|  | |||||||
| @ -3,13 +3,15 @@ | |||||||
|   "theming", |   "theming", | ||||||
|   "components", |   "components", | ||||||
| 
 | 
 | ||||||
|  |   "tweaks", | ||||||
|  |   "font-chooser", | ||||||
|  | 
 | ||||||
|   "integrated-titlebar", |   "integrated-titlebar", | ||||||
|   "tray", |   "tray", | ||||||
|  |   "tabs", | ||||||
|   "always-on-top", |   "always-on-top", | ||||||
|   "view-scale", |   "view-scale", | ||||||
| 
 | 
 | ||||||
|   "tweaks", |  | ||||||
|   "font-chooser", |  | ||||||
|   "outliner", |   "outliner", | ||||||
|   "scroll-to-top", |   "scroll-to-top", | ||||||
|   "indentation-lines", |   "indentation-lines", | ||||||
|  | |||||||
							
								
								
									
										48
									
								
								repo/tabs/mod.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								repo/tabs/mod.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,48 @@ | |||||||
|  | { | ||||||
|  |   "name": "tabs", | ||||||
|  |   "id": "e1692c29-475e-437b-b7ff-3eee872e1a42", | ||||||
|  |   "environments": ["linux", "win32", "darwin"], | ||||||
|  |   "version": "0.3.0", | ||||||
|  |   "description": "open multiple notion pages in a single window.", | ||||||
|  |   "tags": ["extension", "app"], | ||||||
|  |   "authors": [ | ||||||
|  |     { | ||||||
|  |       "name": "dragonwocky", | ||||||
|  |       "email": "thedragonring.bod@gmail.com", | ||||||
|  |       "homepage": "https://dragonwocky.me/", | ||||||
|  |       "avatar": "https://dragonwocky.me/avatar.jpg" | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "css": {}, | ||||||
|  |   "js": {}, | ||||||
|  |   "options": [ | ||||||
|  |     { | ||||||
|  |       "key": "select_modifier", | ||||||
|  |       "label": "tab select modifier", | ||||||
|  |       "tooltip": "**usage: `Modifier+1` to `Modifier+9`, `Modifier+ArrowLeft` and `Modifier+ArrowRight`**", | ||||||
|  |       "type": "select", | ||||||
|  |       "values": [ | ||||||
|  |         "Alt", | ||||||
|  |         "Command", | ||||||
|  |         "Control", | ||||||
|  |         "Super", | ||||||
|  |         "Alt+Shift", | ||||||
|  |         "Command+Shift", | ||||||
|  |         "Control+Shift", | ||||||
|  |         "Super+Shift" | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "type": "hotkey", | ||||||
|  |       "key": "new_tab", | ||||||
|  |       "label": "new tab hotkey", | ||||||
|  |       "value": "Control+T" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "type": "hotkey", | ||||||
|  |       "key": "close_tab", | ||||||
|  |       "label": "close tab hotkey", | ||||||
|  |       "value": "Control+W" | ||||||
|  |     } | ||||||
|  |   ] | ||||||
|  | } | ||||||
| @ -95,6 +95,13 @@ | |||||||
|   background: transparent !important; |   background: transparent !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .notion-topbar-action-buttons { | ||||||
|  |   width: auto !important; | ||||||
|  | } | ||||||
|  | .notion-cursor-listener > [style*='z-index: 102'] { | ||||||
|  |   z-index: 99 !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /* typography */ | /* typography */ | ||||||
| 
 | 
 | ||||||
| [style*='Segoe UI'] { | [style*='Segoe UI'] { | ||||||
|  | |||||||
| @ -4,14 +4,14 @@ | |||||||
|  * (https://notion-enhancer.github.io/) under the MIT license
 |  * (https://notion-enhancer.github.io/) under the MIT license
 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| export default async function ({ env, web }, db) { | export default async function ({ electron, env, web }, db) { | ||||||
|   const runInBackground = await db.get(['run_in_background']); |   const runInBackground = await db.get(['run_in_background']); | ||||||
|   if (!runInBackground) return; |   if (!runInBackground) return; | ||||||
| 
 | 
 | ||||||
|   // force new window creation on create new window hotkey
 |   // force new window creation on create new window hotkey
 | ||||||
|   // hotkey is built into notion, so can't be changed,
 |   // hotkey is built into notion, so can't be changed,
 | ||||||
|   // but is broken by this mod's window duplication prevention
 |   // but is broken by this mod's window duplication prevention
 | ||||||
|   web.addHotkeyListener([env.name === 'darwin' ? 'Meta' : 'Ctrl', 'Shift', 'N'], () => { |   web.addHotkeyListener([env.name === 'darwin' ? 'Meta' : 'Ctrl', 'Shift', 'N'], () => | ||||||
|     __enhancerElectronApi.sendMessage('create-new-window'); |     electron.sendMessage('create-new-window') | ||||||
|   }); |   ); | ||||||
| } | } | ||||||
|  | |||||||
| @ -8,13 +8,12 @@ | |||||||
| 
 | 
 | ||||||
| module.exports = async function ({ env }, db, __exports, __eval) { | module.exports = async function ({ env }, db, __exports, __eval) { | ||||||
|   const electron = require('electron'), |   const electron = require('electron'), | ||||||
|     { isMenuOpen } = require('notion-enhancer/worker.cjs'), |  | ||||||
|     urlHelpers = env.notionRequire('helpers/urlHelpers'), |     urlHelpers = env.notionRequire('helpers/urlHelpers'), | ||||||
|     runInBackground = await db.get(['run_in_background']); |     runInBackground = await db.get(['run_in_background']); | ||||||
|   if (!runInBackground) return; |   if (!runInBackground) return; | ||||||
| 
 | 
 | ||||||
|   let appQuit = false; |   let appQuit = false; | ||||||
|   electron.app.on('before-quit', () => { |   electron.app.once('before-quit', () => { | ||||||
|     appQuit = true; |     appQuit = true; | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
| @ -27,9 +26,8 @@ module.exports = async function ({ env }, db, __exports, __eval) { | |||||||
|       // hijack close event to hide instead
 |       // hijack close event to hide instead
 | ||||||
|       const window = notionCreateWindow(relativeUrl, args); |       const window = notionCreateWindow(relativeUrl, args); | ||||||
|       window.prependListener('close', (e) => { |       window.prependListener('close', (e) => { | ||||||
|         const isLastNotionWindow = |         const isLastWindow = electron.BrowserWindow.getAllWindows().length === 1; | ||||||
|           electron.BrowserWindow.getAllWindows().length === (isMenuOpen() ? 2 : 1); |         if (!appQuit && isLastWindow) { | ||||||
|         if (!appQuit && isLastNotionWindow) { |  | ||||||
|           window.hide(); |           window.hide(); | ||||||
|           e.preventDefault(); |           e.preventDefault(); | ||||||
|           throw new Error('<fake error>: prevent window close'); |           throw new Error('<fake error>: prevent window close'); | ||||||
|  | |||||||
| @ -105,11 +105,3 @@ module.exports = async function ({ env, registry }, db, __exports, __eval) { | |||||||
|   ]); |   ]); | ||||||
|   tray.setContextMenu(contextMenu); |   tray.setContextMenu(contextMenu); | ||||||
| }; | }; | ||||||
| 
 |  | ||||||
| // hide on open
 |  | ||||||
| // maybe only do once to hide first window?
 |  | ||||||
| 
 |  | ||||||
| // exports.createWindow = (...args) => {
 |  | ||||||
| //   warmWindowState.warmedWindow = true;
 |  | ||||||
| //   createWindow(...args);
 |  | ||||||
| // };
 |  | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ | |||||||
|   border: 1px solid var(--theme--ui_divider); |   border: 1px solid var(--theme--ui_divider); | ||||||
|   border-radius: 9999px !important; |   border-radius: 9999px !important; | ||||||
|   margin: 0 4px; |   margin: 0 4px; | ||||||
|   padding: 0 4px; |   padding: 0 5px 0 4px; | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   display: flex; |   display: flex; | ||||||
| @ -51,7 +51,7 @@ | |||||||
| 
 | 
 | ||||||
| .view_scale--counter { | .view_scale--counter { | ||||||
|   font-size: 14px; |   font-size: 14px; | ||||||
|   margin: auto 0; |   margin: auto 4px auto 0; | ||||||
|   width: 5ch; |   width: 5ch; | ||||||
|   text-align: right; |   text-align: right; | ||||||
| } | } | ||||||
| @ -64,9 +64,9 @@ | |||||||
|   align-items: center; |   align-items: center; | ||||||
|   justify-content: center; |   justify-content: center; | ||||||
|   flex-shrink: 0; |   flex-shrink: 0; | ||||||
|   border-radius: 3px; |   border-radius: 9999px; | ||||||
|   height: 28px; |   height: 20px; | ||||||
|   width: 33px; |   width: 20px; | ||||||
|   padding: 0 0.25px 0 0; |   padding: 0 0.25px 0 0; | ||||||
| 
 | 
 | ||||||
|   margin-left: 2px; |   margin-left: 2px; | ||||||
| @ -83,6 +83,6 @@ | |||||||
| } | } | ||||||
| .view_scale--button svg { | .view_scale--button svg { | ||||||
|   display: block; |   display: block; | ||||||
|   width: 20px; |   width: 14px; | ||||||
|   height: 20px; |   height: 14px; | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,16 +5,16 @@ | |||||||
|  * (https://notion-enhancer.github.io/) under the MIT license
 |  * (https://notion-enhancer.github.io/) under the MIT license
 | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| export default async function ({ web, components }, db) { | export default async function ({ electron, web, components }, db) { | ||||||
|   let zoomFactor = (await db.get(['default_zoom'])) / 100, |   let zoomFactor = (await db.get(['default_zoom'])) / 100, | ||||||
|     updateScale = () => {}; |     updateScale = () => {}; | ||||||
|   __enhancerElectronApi.webFrame.setZoomFactor(zoomFactor); |   electron.webFrame.setZoomFactor(zoomFactor); | ||||||
| 
 | 
 | ||||||
|   const zoomOffset = (await db.get(['offset'])) / 100, |   const zoomOffset = (await db.get(['offset'])) / 100, | ||||||
|     zoomMin = 0.5, |     zoomMin = 0.5, | ||||||
|     zoomMax = 2, |     zoomMax = 2, | ||||||
|     getZoomFactor = () => __enhancerElectronApi.webFrame.getZoomFactor(), |     getZoomFactor = () => electron.webFrame.getZoomFactor(), | ||||||
|     setZoomFactor = (zoomFactor) => __enhancerElectronApi.webFrame.setZoomFactor(zoomFactor), |     setZoomFactor = (zoomFactor) => electron.webFrame.setZoomFactor(zoomFactor), | ||||||
|     zoomPlus = (multiplier = 1) => { |     zoomPlus = (multiplier = 1) => { | ||||||
|       zoomFactor = Math.min(getZoomFactor() + zoomOffset * multiplier, zoomMax); |       zoomFactor = Math.min(getZoomFactor() + zoomOffset * multiplier, zoomMax); | ||||||
|       setZoomFactor(zoomFactor); |       setZoomFactor(zoomFactor); | ||||||
| @ -42,7 +42,8 @@ export default async function ({ web, components }, db) { | |||||||
| 
 | 
 | ||||||
|   const showVisualSlider = await db.get(['ui']); |   const showVisualSlider = await db.get(['ui']); | ||||||
|   if (showVisualSlider) { |   if (showVisualSlider) { | ||||||
|     const topbarActionsSelector = '.notion-topbar-action-buttons'; |     const topbarActionsSelector = | ||||||
|  |       '.notion-topbar-action-buttons > div[style="display: flex;"]'; | ||||||
|     await web.whenReady([topbarActionsSelector]); |     await web.whenReady([topbarActionsSelector]); | ||||||
| 
 | 
 | ||||||
|     const $topbarActions = document.querySelector(topbarActionsSelector), |     const $topbarActions = document.querySelector(topbarActionsSelector), | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user