generated from antfu-collective/vitesse-webext
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: открытие sidePanel в chromium, инициализация поисковых кнопок
- Loading branch information
Showing
4 changed files
with
135 additions
and
127 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,10 @@ | ||
{ | ||
"name": "shikimori-search-extension", | ||
"displayName": "Shiki Search", | ||
"version": "1.0.1", | ||
"version": "1.0.2", | ||
"private": true, | ||
"packageManager": "[email protected]", | ||
"description": "[description]", | ||
"description": "Расширение для добавления поисковых кнопок на сайте Shikimori", | ||
"scripts": { | ||
"dev": "npm run clear && cross-env NODE_ENV=development run-p dev:*", | ||
"dev-firefox": "npm run clear && cross-env NODE_ENV=development EXTENSION=firefox run-p dev:*", | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,59 +1,68 @@ | ||
import {onMessage, sendMessage} from 'webext-bridge/background' | ||
import type {Tabs} from 'webextension-polyfill' | ||
import { onMessage, sendMessage } from "webext-bridge/background"; | ||
import type { Tabs } from "webextension-polyfill"; | ||
|
||
const isFirefox = navigator.userAgent.includes('Firefox'); | ||
const isFirefox = navigator.userAgent.includes("Firefox"); | ||
|
||
// only on dev mode | ||
if (import.meta.hot) { | ||
// @ts-expect-error for background HMR | ||
import('/@vite/client') | ||
// load latest content script | ||
import('./contentScriptHMR') | ||
// @ts-expect-error for background HMR | ||
import("/@vite/client"); | ||
// load latest content script | ||
import("./contentScriptHMR"); | ||
} | ||
|
||
if (isFirefox) { | ||
// для переключения боковой панели с помощью кнопки действия в хроме: | ||
browser.action.onClicked.addListener(() => { | ||
browser.sidebarAction.toggle() | ||
}) | ||
// для переключения боковой панели с помощью кнопки действия в хроме: | ||
browser.action.onClicked.addListener(() => { | ||
browser.sidebarAction.toggle(); | ||
}); | ||
} else { | ||
// @ts-expect-error missing types | ||
browser.sidePanel | ||
.setPanelBehavior({ openPanelOnActionClick: true }) | ||
.catch((error: unknown) => console.error(error)); | ||
} | ||
|
||
browser.runtime.onInstalled.addListener((): void => { | ||
// eslint-disable-next-line no-console | ||
console.log('Extension installed') | ||
}) | ||
// eslint-disable-next-line no-console | ||
console.log("Extension installed"); | ||
}); | ||
|
||
let previousTabId = 0 | ||
let previousTabId = 0; | ||
|
||
// пример коммуникации: отправьте заголовок предыдущей вкладки с фоновой страницы | ||
// смотрите shim.d.ts | ||
browser.tabs.onActivated.addListener(async ({tabId}) => { | ||
if (!previousTabId) { | ||
previousTabId = tabId | ||
return | ||
} | ||
|
||
let tab: Tabs.Tab | ||
|
||
try { | ||
tab = await browser.tabs.get(previousTabId) | ||
previousTabId = tabId | ||
} catch { | ||
return | ||
} | ||
|
||
sendMessage('tab-prev', {title: tab.title}, {context: 'content-script', tabId}) | ||
}) | ||
|
||
onMessage('get-current-tab', async () => { | ||
try { | ||
const tab = await browser.tabs.get(previousTabId) | ||
return { | ||
title: tab?.title, | ||
} | ||
} catch { | ||
return { | ||
title: undefined, | ||
} | ||
} | ||
}) | ||
browser.tabs.onActivated.addListener(async ({ tabId }) => { | ||
if (!previousTabId) { | ||
previousTabId = tabId; | ||
return; | ||
} | ||
|
||
let tab: Tabs.Tab; | ||
|
||
try { | ||
tab = await browser.tabs.get(previousTabId); | ||
previousTabId = tabId; | ||
} catch { | ||
return; | ||
} | ||
|
||
sendMessage( | ||
"tab-prev", | ||
{ title: tab.title }, | ||
{ context: "content-script", tabId }, | ||
); | ||
}); | ||
|
||
onMessage("get-current-tab", async () => { | ||
try { | ||
const tab = await browser.tabs.get(previousTabId); | ||
return { | ||
title: tab?.title, | ||
}; | ||
} catch { | ||
return { | ||
title: undefined, | ||
}; | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,85 +1,82 @@ | ||
import fs from 'fs-extra' | ||
import type {Manifest} from 'webextension-polyfill' | ||
import type PkgType from '../package.json' | ||
import {isDev, isFirefox, port, r} from '../scripts/utils' | ||
import fs from "fs-extra"; | ||
import type { Manifest } from "webextension-polyfill"; | ||
import type PkgType from "../package.json"; | ||
import { isDev, isFirefox, port, r } from "../scripts/utils"; | ||
|
||
interface WebExtensionChrome { | ||
side_panel?: { default_path: string } | ||
side_panel?: { default_path: string }; | ||
} | ||
|
||
export async function getManifest() { | ||
const pkg = await fs.readJSON(r('package.json')) as typeof PkgType | ||
const manifest: Manifest.WebExtensionManifest & WebExtensionChrome = { | ||
manifest_version: 3, | ||
name: pkg.displayName || pkg.name, | ||
version: pkg.version, | ||
description: pkg.description, | ||
action: { | ||
default_icon: './assets/icon-512.png', | ||
// default_popup: './dist/popup/index.html', | ||
const pkg = (await fs.readJSON(r("package.json"))) as typeof PkgType; | ||
const manifest: Manifest.WebExtensionManifest & WebExtensionChrome = { | ||
manifest_version: 3, | ||
name: pkg.displayName || pkg.name, | ||
version: pkg.version, | ||
description: pkg.description, | ||
action: { | ||
default_icon: "./assets/icon-512.png", | ||
// default_popup: './dist/popup/index.html', | ||
}, | ||
// не работает для chromium | ||
sidebar_action: { | ||
default_panel: "dist/sidepanel/index.html", | ||
open_at_install: true, | ||
}, | ||
side_panel: { | ||
default_path: "dist/sidepanel/index.html", | ||
}, | ||
// options_ui: { | ||
// page: "./dist/options/index.html", | ||
// open_in_tab: true, | ||
// }, | ||
background: isFirefox | ||
? { | ||
scripts: ["dist/background/index.mjs"], | ||
type: "module", | ||
} | ||
: { | ||
service_worker: "./dist/background/index.mjs", | ||
}, | ||
// does not work for chromium based | ||
sidebar_action: { | ||
default_panel: 'dist/sidepanel/index.html', | ||
open_at_install: true, | ||
}, | ||
side_panel: { | ||
default_path: 'dist/sidepanel/index.html', | ||
}, | ||
options_ui: { | ||
page: './dist/options/index.html', | ||
open_in_tab: true, | ||
}, | ||
background: isFirefox | ||
? { | ||
scripts: ['dist/background/index.mjs'], | ||
type: 'module', | ||
} | ||
: { | ||
service_worker: './dist/background/index.mjs', | ||
}, | ||
icons: { | ||
16: './assets/icon-512.png', | ||
48: './assets/icon-512.png', | ||
128: './assets/icon-512.png', | ||
}, | ||
permissions: [ | ||
'tabs', | ||
'storage', | ||
'activeTab', | ||
'sidePanel', | ||
], | ||
host_permissions: ['*://*/*'], | ||
content_scripts: [ | ||
{ | ||
matches: [ | ||
'https://*.shikimori.one/*', | ||
], | ||
js: [ | ||
'dist/contentScripts/index.global.js', | ||
], | ||
}, | ||
], | ||
web_accessible_resources: [ | ||
{ | ||
resources: ['dist/contentScripts/style.css'], | ||
matches: ['<all_urls>'], | ||
}, | ||
], | ||
content_security_policy: { | ||
extension_pages: isDev | ||
// this is required on dev for Vite script to load | ||
? `script-src \'self\' http://localhost:${port}; object-src \'self\'` | ||
: 'script-src \'self\'; object-src \'self\'', | ||
}, | ||
} | ||
|
||
if (isFirefox) { | ||
delete manifest.side_panel | ||
icons: { | ||
16: "./assets/icon-512.png", | ||
48: "./assets/icon-512.png", | ||
128: "./assets/icon-512.png", | ||
}, | ||
permissions: ["tabs", "storage", "activeTab", "sidePanel"], | ||
host_permissions: ["*://*/*"], | ||
content_scripts: [ | ||
{ | ||
matches: ["https://*.shikimori.one/*"], | ||
js: ["dist/contentScripts/index.global.js"], | ||
}, | ||
], | ||
web_accessible_resources: [ | ||
{ | ||
resources: ["dist/contentScripts/style.css"], | ||
matches: ["<all_urls>"], | ||
}, | ||
], | ||
content_security_policy: { | ||
extension_pages: isDev | ||
? // this is required on dev for Vite script to load | ||
`script-src \'self\' http://localhost:${port}; object-src \'self\'` | ||
: "script-src 'self'; object-src 'self'", | ||
}, | ||
// не нужно для chromium | ||
browser_specific_settings: { | ||
gecko: { | ||
id: "[email protected]", | ||
}, | ||
}, | ||
}; | ||
|
||
} else { | ||
delete manifest.sidebar_action | ||
} | ||
if (isFirefox) { | ||
delete manifest.side_panel; | ||
} else { | ||
delete manifest.sidebar_action; | ||
delete manifest.browser_specific_settings; | ||
} | ||
|
||
return manifest | ||
return manifest; | ||
} |