@fairfox/polly 0.7.1 → 0.7.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/dist/src/background/index.d.ts +1 -1
  2. package/dist/src/background/index.js +10 -3
  3. package/dist/src/background/index.js.map +9 -9
  4. package/dist/src/background/message-router.js +10 -3
  5. package/dist/src/background/message-router.js.map +8 -8
  6. package/dist/src/index.d.ts +9 -9
  7. package/dist/src/index.js +74 -67
  8. package/dist/src/index.js.map +12 -12
  9. package/dist/src/shared/adapters/chrome/context-menus.chrome.d.ts +1 -1
  10. package/dist/src/shared/adapters/chrome/tabs.chrome.d.ts +2 -2
  11. package/dist/src/shared/adapters/context-menus.adapter.d.ts +1 -1
  12. package/dist/src/shared/adapters/index.d.ts +4 -4
  13. package/dist/src/shared/adapters/index.js +9 -2
  14. package/dist/src/shared/adapters/index.js.map +6 -6
  15. package/dist/src/shared/adapters/tabs.adapter.d.ts +2 -2
  16. package/dist/src/shared/lib/context-helpers.js +10 -3
  17. package/dist/src/shared/lib/context-helpers.js.map +8 -8
  18. package/dist/src/shared/lib/message-bus.js +10 -3
  19. package/dist/src/shared/lib/message-bus.js.map +7 -7
  20. package/dist/src/shared/lib/state.js +10 -3
  21. package/dist/src/shared/lib/state.js.map +8 -8
  22. package/dist/src/shared/state/app-state.js +10 -3
  23. package/dist/src/shared/state/app-state.js.map +8 -8
  24. package/dist/tools/init/src/cli.js +17 -2
  25. package/dist/tools/init/src/cli.js.map +4 -4
  26. package/dist/tools/init/templates/pwa/package.json.template +3 -3
  27. package/dist/tools/teach/src/cli.js +2712 -2442
  28. package/dist/tools/teach/src/cli.js.map +11 -11
  29. package/dist/tools/teach/src/index.js +1379 -1379
  30. package/dist/tools/teach/src/index.js.map +10 -10
  31. package/dist/tools/test/src/adapters/index.d.ts +8 -8
  32. package/dist/tools/test/src/adapters/index.js +3 -2
  33. package/dist/tools/test/src/adapters/index.js.map +6 -6
  34. package/dist/tools/test/src/index.d.ts +3 -3
  35. package/dist/tools/test/src/index.js +3 -2
  36. package/dist/tools/test/src/index.js.map +6 -6
  37. package/dist/tools/verify/src/cli.js +190 -68
  38. package/dist/tools/verify/src/cli.js.map +8 -8
  39. package/dist/tools/visualize/src/cli.js +18 -3
  40. package/dist/tools/visualize/src/cli.js.map +4 -4
  41. package/package.json +27 -16
@@ -1,27 +1,27 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../src/shared/adapters/chrome/context-menus.chrome.ts", "../src/shared/adapters/chrome/offscreen.chrome.ts", "../src/shared/adapters/chrome/runtime.chrome.ts", "../src/shared/adapters/chrome/storage.chrome.ts", "../src/shared/adapters/chrome/tabs.chrome.ts", "../src/shared/adapters/chrome/window.chrome.ts", "../src/shared/adapters/fetch.adapter.ts", "../src/shared/adapters/logger.adapter.ts", "../src/shared/adapters/index.ts", "../src/shared/types/messages.ts", "../src/shared/lib/errors.ts", "../src/shared/lib/context-specific-helpers.ts", "../src/shared/lib/handler-execution-tracker.ts", "../src/shared/lib/message-bus.ts", "../src/shared/lib/state.ts", "../src/shared/state/app-state.ts", "../src/shared/lib/context-helpers.ts", "../src/shared/lib/test-helpers.ts"],
3
+ "sources": ["../src/shared/adapters/chrome/context-menus.chrome.ts", "../src/shared/adapters/chrome/offscreen.chrome.ts", "../src/shared/adapters/chrome/runtime.chrome.ts", "../src/shared/adapters/chrome/storage.chrome.ts", "../src/shared/adapters/chrome/tabs.chrome.ts", "../src/shared/adapters/chrome/window.chrome.ts", "../src/shared/adapters/fetch.adapter.ts", "../src/shared/adapters/logger.adapter.ts", "../src/shared/adapters/index.ts", "../src/shared/types/messages.ts", "../src/shared/lib/errors.ts", "../src/shared/lib/context-specific-helpers.ts", "../src/shared/lib/handler-execution-tracker.ts", "../src/shared/lib/message-bus.ts", "../src/shared/lib/context-helpers.ts", "../src/shared/lib/state.ts", "../src/shared/lib/test-helpers.ts", "../src/shared/state/app-state.ts"],
4
4
  "sourcesContent": [
5
- "// Chrome context menus adapter implementation\n\nimport type { ContextMenusAdapter } from \"../context-menus.adapter\";\n\nexport class ChromeContextMenusAdapter implements ContextMenusAdapter {\n async create(createProperties: chrome.contextMenus.CreateProperties): Promise<void> {\n return new Promise((resolve, reject) => {\n chrome.contextMenus.create(createProperties, () => {\n if (chrome.runtime.lastError) {\n reject(new Error(chrome.runtime.lastError.message));\n } else {\n resolve();\n }\n });\n });\n }\n\n async update(id: string, updateProperties: chrome.contextMenus.UpdateProperties): Promise<void> {\n await chrome.contextMenus.update(id, updateProperties);\n }\n\n async remove(id: string): Promise<void> {\n await chrome.contextMenus.remove(id);\n }\n\n async removeAll(): Promise<void> {\n await chrome.contextMenus.removeAll();\n }\n\n onClicked(\n callback: (info: chrome.contextMenus.OnClickData, tab?: chrome.tabs.Tab) => void\n ): void {\n chrome.contextMenus.onClicked.addListener(callback);\n }\n}\n",
5
+ "// Chrome context menus adapter implementation\n\nimport type { ContextMenusAdapter } from \"../context-menus.adapter\";\n\nexport class ChromeContextMenusAdapter implements ContextMenusAdapter {\n async create(createProperties: chrome.contextMenus.CreateProperties): Promise<void> {\n return new Promise((resolve, reject) => {\n chrome.contextMenus.create(createProperties, () => {\n if (chrome.runtime.lastError) {\n reject(new Error(chrome.runtime.lastError.message));\n } else {\n resolve();\n }\n });\n });\n }\n\n async update(\n id: string,\n updateProperties: Omit<chrome.contextMenus.CreateProperties, \"id\">\n ): Promise<void> {\n await chrome.contextMenus.update(id, updateProperties);\n }\n\n async remove(id: string): Promise<void> {\n await chrome.contextMenus.remove(id);\n }\n\n async removeAll(): Promise<void> {\n await chrome.contextMenus.removeAll();\n }\n\n onClicked(\n callback: (info: chrome.contextMenus.OnClickData, tab?: chrome.tabs.Tab) => void\n ): void {\n chrome.contextMenus.onClicked.addListener(callback);\n }\n}\n",
6
6
  "// Chrome offscreen adapter implementation\n\nimport type { CreateOffscreenDocumentParameters, OffscreenAdapter } from \"../offscreen.adapter\";\n\nexport class ChromeOffscreenAdapter implements OffscreenAdapter {\n async createDocument(parameters: CreateOffscreenDocumentParameters): Promise<void> {\n await chrome.offscreen.createDocument({\n url: parameters.url,\n reasons: parameters.reasons as chrome.offscreen.Reason[],\n justification: parameters.justification,\n });\n }\n\n async closeDocument(): Promise<void> {\n await chrome.offscreen.closeDocument();\n }\n\n async hasDocument(): Promise<boolean> {\n // Chrome doesn't provide a direct API, so we query for offscreen contexts\n const existingContexts = await chrome.runtime.getContexts({\n contextTypes: [\"OFFSCREEN_DOCUMENT\" as chrome.runtime.ContextType],\n });\n return existingContexts.length > 0;\n }\n}\n",
7
7
  "// Chrome runtime adapter implementation\n\nimport type { MessageSender, PortAdapter, RuntimeAdapter } from \"../runtime.adapter\";\n\ntype MessageListener = (\n message: unknown,\n sender: MessageSender,\n sendResponse: (response: unknown) => void\n) => undefined | boolean;\n\ntype ChromeMessageListener = (\n message: unknown,\n sender: chrome.runtime.MessageSender,\n sendResponse: (response?: unknown) => void\n) => undefined | boolean;\n\nexport class ChromeRuntimeAdapter implements RuntimeAdapter {\n private messageListeners = new Map<MessageListener, ChromeMessageListener>();\n private static listenerCount = 0;\n\n sendMessage<T>(message: T): Promise<unknown> {\n return chrome.runtime.sendMessage(message);\n }\n\n onMessage(\n callback: (\n message: unknown,\n sender: MessageSender,\n sendResponse: (response: unknown) => void\n ) => undefined | boolean\n ): void {\n const wrappedCallback = (\n message: unknown,\n sender: chrome.runtime.MessageSender,\n sendResponse: (response?: unknown) => void\n ) => {\n const mappedSender: MessageSender = {\n ...(sender.tab && {\n tab: {\n id: sender.tab.id ?? 0,\n url: sender.tab.url ?? \"\",\n title: sender.tab.title ?? \"\",\n },\n }),\n ...(sender.frameId !== undefined && { frameId: sender.frameId }),\n ...(sender.url && { url: sender.url }),\n };\n return callback(message, mappedSender, sendResponse);\n };\n\n this.messageListeners.set(callback, wrappedCallback);\n // Chrome's listener signature uses void | boolean, ours uses undefined | boolean\n // These are compatible - undefined is assignable to void for return types\n chrome.runtime.onMessage.addListener(\n wrappedCallback as (\n message: unknown,\n sender: chrome.runtime.MessageSender,\n sendResponse: (response?: unknown) => void\n ) => undefined | boolean\n );\n\n // Track listener count and warn if multiple listeners registered\n ChromeRuntimeAdapter.listenerCount++;\n\n if (ChromeRuntimeAdapter.listenerCount > 1) {\n console.warn(\n `⚠️ WARNING: ${ChromeRuntimeAdapter.listenerCount} chrome.runtime.onMessage listeners registered!\\n\\nMultiple listeners will cause message handlers to execute multiple times.\\nThis is usually caused by:\\n 1. Creating both MessageBus and MessageRouter with separate listeners\\n 2. Calling createBackground() multiple times\\n 3. Calling getMessageBus('background') after createBackground()\\n\\nFix: In background scripts, use createBackground() ONCE at startup.\\nDo not call getMessageBus('background') separately.`\n );\n }\n }\n\n removeMessageListener(\n callback: (\n message: unknown,\n sender: MessageSender,\n sendResponse: (response: unknown) => void\n ) => undefined | boolean\n ): void {\n const wrappedCallback = this.messageListeners.get(callback);\n if (wrappedCallback) {\n // Type-safe cast: wrappedCallback is stored with compatible signature\n chrome.runtime.onMessage.removeListener(\n wrappedCallback as (\n message: unknown,\n sender: chrome.runtime.MessageSender,\n sendResponse: (response?: unknown) => void\n ) => undefined | boolean\n );\n this.messageListeners.delete(callback);\n\n // Decrement listener count\n ChromeRuntimeAdapter.listenerCount = Math.max(0, ChromeRuntimeAdapter.listenerCount - 1);\n }\n }\n\n connect(name: string): PortAdapter {\n const port = chrome.runtime.connect({ name });\n return new ChromePortAdapter(port);\n }\n\n onConnect(callback: (port: PortAdapter) => void): void {\n chrome.runtime.onConnect.addListener((port) => {\n callback(new ChromePortAdapter(port));\n });\n }\n\n getURL(path: string): string {\n return chrome.runtime.getURL(path);\n }\n\n getId(): string {\n return chrome.runtime.id;\n }\n\n openOptionsPage(): void {\n chrome.runtime.openOptionsPage();\n }\n}\n\nclass ChromePortAdapter implements PortAdapter {\n private listeners = {\n message: new Set<(message: unknown) => void>(),\n disconnect: new Set<() => void>(),\n };\n\n constructor(private port: chrome.runtime.Port) {\n // Set up Chrome port listeners\n this.port.onMessage.addListener((message) => {\n for (const callback of this.listeners.message) {\n callback(message);\n }\n });\n\n this.port.onDisconnect.addListener(() => {\n for (const callback of this.listeners.disconnect) {\n callback();\n }\n });\n }\n\n get name(): string {\n return this.port.name;\n }\n\n postMessage(message: unknown): void {\n this.port.postMessage(message);\n }\n\n onMessage(callback: (message: unknown) => void): void {\n this.listeners.message.add(callback);\n }\n\n onDisconnect(callback: () => void): void {\n this.listeners.disconnect.add(callback);\n }\n\n disconnect(): void {\n this.port.disconnect();\n }\n}\n",
8
- "// Chrome storage adapter implementation\n\nimport type { StorageAdapter, StorageChanges } from \"../storage.adapter\";\n\nexport class ChromeStorageAdapter implements StorageAdapter {\n async get<T = Record<string, unknown>>(keys: string | string[] | null): Promise<T> {\n return (await chrome.storage.local.get(keys)) as T;\n }\n\n async set(items: Record<string, unknown>): Promise<void> {\n await chrome.storage.local.set(items);\n }\n\n async remove(keys: string | string[]): Promise<void> {\n await chrome.storage.local.remove(keys);\n }\n\n async clear(): Promise<void> {\n await chrome.storage.local.clear();\n }\n\n onChanged(callback: (changes: StorageChanges, areaName: string) => void): void {\n chrome.storage.onChanged.addListener((changes, areaName) => {\n const mappedChanges: StorageChanges = {};\n for (const [key, change] of Object.entries(changes)) {\n mappedChanges[key] = {\n oldValue: change.oldValue,\n newValue: change.newValue,\n };\n }\n callback(mappedChanges, areaName);\n });\n }\n}\n",
9
- "// Chrome tabs adapter implementation\n\nimport type { TabsAdapter } from \"../tabs.adapter\";\n\nexport class ChromeTabsAdapter implements TabsAdapter {\n async query(queryInfo: chrome.tabs.QueryInfo): Promise<chrome.tabs.Tab[]> {\n return chrome.tabs.query(queryInfo);\n }\n\n async get(tabId: number): Promise<chrome.tabs.Tab> {\n return chrome.tabs.get(tabId);\n }\n\n async sendMessage(tabId: number, message: unknown): Promise<unknown> {\n return chrome.tabs.sendMessage(tabId, message);\n }\n\n async reload(tabId: number, reloadProperties?: { bypassCache?: boolean }): Promise<void> {\n await chrome.tabs.reload(tabId, reloadProperties);\n }\n\n onRemoved(callback: (tabId: number, removeInfo: chrome.tabs.TabRemoveInfo) => void): void {\n chrome.tabs.onRemoved.addListener(callback);\n }\n\n onUpdated(\n callback: (tabId: number, changeInfo: chrome.tabs.TabChangeInfo, tab: chrome.tabs.Tab) => void\n ): void {\n chrome.tabs.onUpdated.addListener(callback);\n }\n\n onActivated(callback: (activeInfo: { tabId: number; windowId: number }) => void): void {\n chrome.tabs.onActivated.addListener(callback);\n }\n\n async create(createProperties: chrome.tabs.CreateProperties): Promise<chrome.tabs.Tab> {\n return chrome.tabs.create(createProperties);\n }\n}\n",
8
+ "// Chrome storage adapter implementation\n\nimport type { StorageAdapter, StorageChanges } from \"../storage.adapter\";\n\nexport class ChromeStorageAdapter implements StorageAdapter {\n async get<T = Record<string, unknown>>(keys: string | string[] | null): Promise<T> {\n if (keys === null) {\n return (await chrome.storage.local.get()) as T;\n }\n return (await chrome.storage.local.get(keys as never)) as T;\n }\n\n async set(items: Record<string, unknown>): Promise<void> {\n await chrome.storage.local.set(items);\n }\n\n async remove(keys: string | string[]): Promise<void> {\n await chrome.storage.local.remove(keys);\n }\n\n async clear(): Promise<void> {\n await chrome.storage.local.clear();\n }\n\n onChanged(callback: (changes: StorageChanges, areaName: string) => void): void {\n chrome.storage.onChanged.addListener((changes, areaName) => {\n const mappedChanges: StorageChanges = {};\n for (const [key, change] of Object.entries(changes)) {\n mappedChanges[key] = {\n oldValue: change.oldValue,\n newValue: change.newValue,\n };\n }\n callback(mappedChanges, areaName);\n });\n }\n}\n",
9
+ "// Chrome tabs adapter implementation\n\nimport type { TabsAdapter } from \"../tabs.adapter\";\n\nexport class ChromeTabsAdapter implements TabsAdapter {\n async query(queryInfo: chrome.tabs.QueryInfo): Promise<chrome.tabs.Tab[]> {\n return chrome.tabs.query(queryInfo);\n }\n\n async get(tabId: number): Promise<chrome.tabs.Tab> {\n return chrome.tabs.get(tabId);\n }\n\n async sendMessage(tabId: number, message: unknown): Promise<unknown> {\n return chrome.tabs.sendMessage(tabId, message);\n }\n\n async reload(tabId: number, reloadProperties?: { bypassCache?: boolean }): Promise<void> {\n if (reloadProperties) {\n await chrome.tabs.reload(tabId, reloadProperties);\n } else {\n await chrome.tabs.reload(tabId);\n }\n }\n\n onRemoved(callback: (tabId: number, removeInfo: chrome.tabs.OnRemovedInfo) => void): void {\n chrome.tabs.onRemoved.addListener(callback);\n }\n\n onUpdated(\n callback: (tabId: number, changeInfo: chrome.tabs.OnUpdatedInfo, tab: chrome.tabs.Tab) => void\n ): void {\n chrome.tabs.onUpdated.addListener(callback);\n }\n\n onActivated(callback: (activeInfo: { tabId: number; windowId: number }) => void): void {\n chrome.tabs.onActivated.addListener(callback);\n }\n\n async create(createProperties: chrome.tabs.CreateProperties): Promise<chrome.tabs.Tab> {\n return chrome.tabs.create(createProperties);\n }\n}\n",
10
10
  "// Chrome window adapter implementation\n\nimport type { WindowAdapter } from \"../window.adapter\";\n\nexport class ChromeWindowAdapter implements WindowAdapter {\n postMessage(message: unknown, targetOrigin: string): void {\n window.postMessage(message, targetOrigin);\n }\n\n addEventListener(type: \"message\", listener: (event: MessageEvent) => void): void {\n window.addEventListener(type, listener as EventListener);\n }\n\n removeEventListener(type: \"message\", listener: (event: MessageEvent) => void): void {\n window.removeEventListener(type, listener as EventListener);\n }\n}\n",
11
11
  "// Fetch adapter interface (wraps fetch API)\n\nexport interface FetchAdapter {\n fetch(input: string | URL, init?: RequestInit): Promise<Response>;\n}\n\nexport class BrowserFetchAdapter implements FetchAdapter {\n fetch(input: string | URL, init?: RequestInit): Promise<Response> {\n return fetch(input, init);\n }\n}\n",
12
12
  "import type { Context, LogLevel } from \"../types/messages\";\n// Logger adapter interface (message-based centralized logging)\nimport type { RuntimeAdapter } from \"./runtime.adapter\";\n\nexport interface LoggerAdapter {\n /**\n * Debug-level logging (verbose, development info)\n */\n debug(message: string, context?: Record<string, unknown>): void;\n\n /**\n * Info-level logging (general information)\n */\n info(message: string, context?: Record<string, unknown>): void;\n\n /**\n * Warning-level logging (non-critical issues)\n */\n warn(message: string, context?: Record<string, unknown>): void;\n\n /**\n * Error-level logging (errors and exceptions)\n */\n error(message: string, error?: Error, context?: Record<string, unknown>): void;\n\n /**\n * Log with explicit level\n */\n log(level: LogLevel, message: string, context?: Record<string, unknown>): void;\n}\n\nexport interface MessageLoggerOptions {\n consoleMirror?: boolean; // Also log to console (for development)\n fallbackToConsole?: boolean; // Log to console if message send fails (default: true)\n}\n\n/**\n * Message-based logger that sends LOG messages to background LogStore\n * Uses RuntimeAdapter directly to avoid circular dependency with MessageBus\n */\nexport class MessageLoggerAdapter implements LoggerAdapter {\n constructor(\n private runtime: RuntimeAdapter,\n private sourceContext: Context,\n private options?: MessageLoggerOptions\n ) {}\n\n debug(message: string, context?: Record<string, unknown>): void {\n this.sendLog(\"debug\", message, context);\n }\n\n info(message: string, context?: Record<string, unknown>): void {\n this.sendLog(\"info\", message, context);\n }\n\n warn(message: string, context?: Record<string, unknown>): void {\n this.sendLog(\"warn\", message, context);\n }\n\n error(message: string, error?: Error, context?: Record<string, unknown>): void {\n this.sendLog(\"error\", message, context, error);\n }\n\n log(level: LogLevel, message: string, context?: Record<string, unknown>): void {\n this.sendLog(level, message, context);\n }\n\n private sendLog(\n level: LogLevel,\n message: string,\n context?: Record<string, unknown>,\n error?: Error\n ): void {\n // Optional console mirror for development\n if (this.options?.consoleMirror) {\n const consoleMethod = console[level] || console.log;\n consoleMethod(`[${this.sourceContext}]`, message, context || \"\", error || \"\");\n }\n\n // Send LOG message to background (fire-and-forget)\n const logMessage = {\n type: \"LOG\" as const,\n level,\n message,\n context,\n error: error?.message,\n stack: error?.stack,\n source: this.sourceContext,\n timestamp: Date.now(),\n };\n\n // Use runtime.sendMessage for fire-and-forget messaging\n this.runtime.sendMessage(logMessage).catch((sendError) => {\n // Fallback to console if messaging fails\n if (this.options?.fallbackToConsole !== false) {\n console[level](`[${this.sourceContext}] ${message}`, context || \"\", error || \"\");\n console.warn(\"Failed to send log message:\", sendError);\n }\n });\n }\n}\n",
13
- "// Adapter factory and exports\n\nimport { ChromeContextMenusAdapter } from \"./chrome/context-menus.chrome\";\nimport { ChromeOffscreenAdapter } from \"./chrome/offscreen.chrome\";\nimport { ChromeRuntimeAdapter } from \"./chrome/runtime.chrome\";\nimport { ChromeStorageAdapter } from \"./chrome/storage.chrome\";\nimport { ChromeTabsAdapter } from \"./chrome/tabs.chrome\";\nimport { ChromeWindowAdapter } from \"./chrome/window.chrome\";\nimport { BrowserFetchAdapter } from \"./fetch.adapter\";\nimport { MessageLoggerAdapter } from \"./logger.adapter\";\n\nimport type { Context } from \"../types/messages\";\nimport type { ContextMenusAdapter } from \"./context-menus.adapter\";\nimport type { FetchAdapter } from \"./fetch.adapter\";\nimport type { LoggerAdapter } from \"./logger.adapter\";\nimport type { OffscreenAdapter } from \"./offscreen.adapter\";\nimport type { RuntimeAdapter } from \"./runtime.adapter\";\nimport type { StorageAdapter } from \"./storage.adapter\";\nimport type { TabsAdapter } from \"./tabs.adapter\";\nimport type { WindowAdapter } from \"./window.adapter\";\n\nexport interface ExtensionAdapters {\n runtime: RuntimeAdapter;\n storage: StorageAdapter;\n tabs: TabsAdapter;\n window: WindowAdapter;\n offscreen: OffscreenAdapter;\n contextMenus: ContextMenusAdapter;\n fetch: FetchAdapter;\n logger: LoggerAdapter;\n}\n\nexport interface CreateChromeAdaptersOptions {\n consoleMirror?: boolean; // Mirror logs to console for development\n}\n\n/**\n * Create Chrome-specific adapters with context\n */\nexport function createChromeAdapters(\n context: Context,\n options?: CreateChromeAdaptersOptions\n): ExtensionAdapters {\n const runtime = new ChromeRuntimeAdapter();\n\n return {\n runtime,\n storage: new ChromeStorageAdapter(),\n tabs: new ChromeTabsAdapter(),\n window: new ChromeWindowAdapter(),\n offscreen: new ChromeOffscreenAdapter(),\n contextMenus: new ChromeContextMenusAdapter(),\n fetch: new BrowserFetchAdapter(),\n logger: new MessageLoggerAdapter(runtime, context, {\n ...(options?.consoleMirror !== undefined && { consoleMirror: options.consoleMirror }),\n fallbackToConsole: true,\n }),\n };\n}\n\n// Re-export types\nexport * from \"./runtime.adapter\";\nexport * from \"./storage.adapter\";\nexport * from \"./tabs.adapter\";\nexport * from \"./window.adapter\";\nexport * from \"./offscreen.adapter\";\nexport * from \"./context-menus.adapter\";\nexport * from \"./fetch.adapter\";\nexport * from \"./logger.adapter\";\n",
13
+ "// Adapter factory and exports\n\nimport type { Context } from \"../types/messages\";\nimport { ChromeContextMenusAdapter } from \"./chrome/context-menus.chrome\";\nimport { ChromeOffscreenAdapter } from \"./chrome/offscreen.chrome\";\nimport { ChromeRuntimeAdapter } from \"./chrome/runtime.chrome\";\nimport { ChromeStorageAdapter } from \"./chrome/storage.chrome\";\nimport { ChromeTabsAdapter } from \"./chrome/tabs.chrome\";\nimport { ChromeWindowAdapter } from \"./chrome/window.chrome\";\nimport type { ContextMenusAdapter } from \"./context-menus.adapter\";\nimport type { FetchAdapter } from \"./fetch.adapter\";\nimport { BrowserFetchAdapter } from \"./fetch.adapter\";\nimport type { LoggerAdapter } from \"./logger.adapter\";\nimport { MessageLoggerAdapter } from \"./logger.adapter\";\nimport type { OffscreenAdapter } from \"./offscreen.adapter\";\nimport type { RuntimeAdapter } from \"./runtime.adapter\";\nimport type { StorageAdapter } from \"./storage.adapter\";\nimport type { TabsAdapter } from \"./tabs.adapter\";\nimport type { WindowAdapter } from \"./window.adapter\";\n\nexport interface ExtensionAdapters {\n runtime: RuntimeAdapter;\n storage: StorageAdapter;\n tabs: TabsAdapter;\n window: WindowAdapter;\n offscreen: OffscreenAdapter;\n contextMenus: ContextMenusAdapter;\n fetch: FetchAdapter;\n logger: LoggerAdapter;\n}\n\nexport interface CreateChromeAdaptersOptions {\n consoleMirror?: boolean; // Mirror logs to console for development\n}\n\n/**\n * Create Chrome-specific adapters with context\n */\nexport function createChromeAdapters(\n context: Context,\n options?: CreateChromeAdaptersOptions\n): ExtensionAdapters {\n const runtime = new ChromeRuntimeAdapter();\n\n return {\n runtime,\n storage: new ChromeStorageAdapter(),\n tabs: new ChromeTabsAdapter(),\n window: new ChromeWindowAdapter(),\n offscreen: new ChromeOffscreenAdapter(),\n contextMenus: new ChromeContextMenusAdapter(),\n fetch: new BrowserFetchAdapter(),\n logger: new MessageLoggerAdapter(runtime, context, {\n ...(options?.consoleMirror !== undefined && { consoleMirror: options.consoleMirror }),\n fallbackToConsole: true,\n }),\n };\n}\n\nexport * from \"./context-menus.adapter\";\nexport * from \"./fetch.adapter\";\nexport * from \"./logger.adapter\";\nexport * from \"./offscreen.adapter\";\n// Re-export types\nexport * from \"./runtime.adapter\";\nexport * from \"./storage.adapter\";\nexport * from \"./tabs.adapter\";\nexport * from \"./window.adapter\";\n",
14
14
  "// Type definitions for all messages in the extension\n\n/**\n * Base message interface that all messages must satisfy.\n * This allows users to define custom messages alongside framework messages.\n */\nexport interface BaseMessage {\n type: string;\n}\n\nexport type Context =\n | \"background\"\n | \"content\"\n | \"page\"\n | \"devtools\"\n | \"popup\"\n | \"options\"\n | \"sidepanel\"\n | \"offscreen\";\n\n// All contexts (useful for broadcast)\nexport const ALL_CONTEXTS: Context[] = [\n \"background\",\n \"content\",\n \"page\",\n \"devtools\",\n \"popup\",\n \"options\",\n \"sidepanel\",\n \"offscreen\",\n] as const;\n\n// Settings schema\nexport type Settings = {\n theme: \"light\" | \"dark\" | \"auto\";\n autoSync: boolean;\n debugMode: boolean;\n notifications: boolean;\n apiEndpoint: string;\n refreshInterval: number;\n};\n\nexport const defaultSettings: Settings = {\n theme: \"auto\",\n autoSync: true,\n debugMode: false,\n notifications: true,\n apiEndpoint: \"https://api.example.com\",\n refreshInterval: 60000,\n};\n\n// Logging types\nexport type LogLevel = \"debug\" | \"info\" | \"warn\" | \"error\";\n\nexport type LogEntry = {\n id: string;\n level: LogLevel;\n message: string;\n context?: Record<string, unknown>;\n error?: string;\n stack?: string;\n source: Context;\n timestamp: number;\n};\n\n// All possible messages (discriminated union)\nexport type ExtensionMessage =\n // DOM Operations (handled by Content Script)\n | { type: \"DOM_QUERY\"; selector: string }\n | { type: \"DOM_UPDATE\"; selector: string; content: string }\n | {\n type: \"DOM_INSERT\";\n position: \"beforebegin\" | \"afterbegin\" | \"beforeend\" | \"afterend\";\n html: string;\n }\n | { type: \"DOM_REMOVE\"; selector: string }\n\n // Page Script Operations (handled by Page Script)\n | { type: \"PAGE_EVAL\"; code: string }\n | { type: \"PAGE_GET_VAR\"; varName: string }\n | { type: \"PAGE_CALL_FN\"; fnName: string; args: unknown[] }\n | { type: \"PAGE_SET_VAR\"; varName: string; value: unknown }\n\n // API Operations (handled by Background)\n | {\n type: \"API_REQUEST\";\n endpoint: string;\n method: \"GET\" | \"POST\" | \"PUT\" | \"DELETE\";\n body?: unknown;\n headers?: Record<string, string>;\n }\n | {\n type: \"API_BATCH\";\n requests: Array<{ endpoint: string; method: string; body?: unknown }>;\n }\n\n // Clipboard Operations (handled by Offscreen)\n | { type: \"CLIPBOARD_WRITE\"; text: string }\n | { type: \"CLIPBOARD_WRITE_HTML\"; html: string }\n | { type: \"CLIPBOARD_WRITE_RICH\"; data: { text: string; html: string } }\n | { type: \"CLIPBOARD_READ\" }\n\n // Context Menu (handled by Background)\n | {\n type: \"CONTEXT_MENU_CLICKED\";\n menuId: string;\n info: chrome.contextMenus.OnClickData;\n tabId: number;\n }\n | {\n type: \"CONTEXT_MENU_CREATE\";\n id: string;\n title: string;\n contexts: chrome.contextMenus.ContextType[];\n }\n | { type: \"CONTEXT_MENU_REMOVE\"; id: string }\n\n // State Sync (broadcast) - Internal only, handled by state primitives\n | {\n type: \"STATE_SYNC\";\n key: string;\n value: unknown;\n clock: number;\n }\n\n // Tab Operations (handled by Background)\n | { type: \"TAB_QUERY\"; queryInfo: chrome.tabs.QueryInfo }\n | { type: \"TAB_GET_CURRENT\" }\n | { type: \"TAB_RELOAD\"; tabId: number }\n\n // DevTools Operations\n | { type: \"DEVTOOLS_INSPECT_ELEMENT\"; selector: string }\n | {\n type: \"DEVTOOLS_LOG\";\n level: \"log\" | \"warn\" | \"error\";\n message: string;\n data?: unknown;\n }\n\n // Logging (handled by Background LogStore)\n | {\n type: \"LOG\";\n level: LogLevel;\n message: string;\n context?: Record<string, unknown>;\n error?: string;\n stack?: string;\n source: Context;\n timestamp: number;\n }\n | {\n type: \"LOGS_GET\";\n filters?: {\n level?: LogLevel;\n source?: Context;\n since?: number;\n limit?: number;\n };\n }\n | { type: \"LOGS_CLEAR\" }\n | { type: \"LOGS_EXPORT\" }\n\n // Test Messages (only used in tests)\n | { type: \"TEST_MESSAGE\"; data?: unknown }\n | { type: \"TEST\"; iteration?: number }\n | { type: \"CUSTOM_MESSAGE\"; data?: unknown }\n | { type: \"SETTINGS_GET\" }\n | {\n type: \"SIGNAL_UPDATE\";\n key?: string;\n value?: unknown;\n signalId?: string;\n source?: Context;\n }\n | {\n type: \"USER_DATA\";\n password?: string;\n apiKey?: string;\n [key: string]: unknown;\n };\n\n// Helper: Look up the full message type from a union based on the 'type' discriminator\ntype LookupMessage<TUnion, TType extends string> = TUnion extends { type: TType } ? TUnion : never;\n\n// Extract response type from message using phantom type\n// If message has __response field (phantom type), use it; otherwise infer from framework messages\nexport type MessageResponse<T extends BaseMessage> =\n // First, try to find the matching message in the union by type discriminator\n T extends { type: infer TType extends string }\n ? LookupMessage<T, TType> extends { readonly __response?: infer R }\n ? R // Found phantom type, use it\n : T extends ExtensionMessage\n ? // Framework message - infer from type\n // DOM Operations\n T extends { type: \"DOM_QUERY\" }\n ? {\n elements: Array<{\n tag: string;\n text: string;\n html: string;\n attrs: Record<string, string>;\n rect?: DOMRect;\n }>;\n }\n : T extends { type: \"DOM_UPDATE\" }\n ? { success: boolean }\n : T extends { type: \"DOM_INSERT\" }\n ? { success: boolean }\n : T extends { type: \"DOM_REMOVE\" }\n ? { success: boolean; count: number }\n : // Page Script Operations\n T extends { type: \"PAGE_EVAL\" }\n ? { result: unknown; error?: string }\n : T extends { type: \"PAGE_GET_VAR\" }\n ? { value: unknown; exists: boolean }\n : T extends { type: \"PAGE_CALL_FN\" }\n ? { result: unknown; error?: string }\n : T extends { type: \"PAGE_SET_VAR\" }\n ? { success: boolean }\n : // API Operations\n T extends { type: \"API_REQUEST\" }\n ? {\n data: unknown;\n status: number;\n statusText: string;\n headers: Record<string, string>;\n error?: string;\n }\n : T extends { type: \"API_BATCH\" }\n ? {\n results: Array<{\n data: unknown;\n status: number;\n error?: string;\n }>;\n }\n : // Clipboard Operations\n T extends { type: \"CLIPBOARD_WRITE\" }\n ? { success: boolean }\n : T extends { type: \"CLIPBOARD_WRITE_HTML\" }\n ? { success: boolean }\n : T extends { type: \"CLIPBOARD_WRITE_RICH\" }\n ? { success: boolean }\n : T extends { type: \"CLIPBOARD_READ\" }\n ? { text: string }\n : // Context Menu\n T extends { type: \"CONTEXT_MENU_CLICKED\" }\n ? undefined\n : T extends { type: \"CONTEXT_MENU_CREATE\" }\n ? { success: boolean }\n : T extends { type: \"CONTEXT_MENU_REMOVE\" }\n ? { success: boolean }\n : // State Sync\n T extends { type: \"STATE_SYNC\" }\n ? undefined\n : // Tab Operations\n T extends { type: \"TAB_QUERY\" }\n ? { tabs: chrome.tabs.Tab[] }\n : T extends {\n type: \"TAB_GET_CURRENT\";\n }\n ? { tab: chrome.tabs.Tab }\n : T extends {\n type: \"TAB_RELOAD\";\n }\n ? { success: boolean }\n : // DevTools Operations\n T extends {\n type: \"DEVTOOLS_INSPECT_ELEMENT\";\n }\n ? {\n success: boolean;\n }\n : T extends {\n type: \"DEVTOOLS_LOG\";\n }\n ? undefined\n : // Logging Operations\n T extends {\n type: \"LOG\";\n }\n ? {\n success: boolean;\n }\n : T extends {\n type: \"LOGS_GET\";\n }\n ? {\n logs: LogEntry[];\n }\n : T extends {\n type: \"LOGS_CLEAR\";\n }\n ? {\n success: boolean;\n count: number;\n }\n : T extends {\n type: \"LOGS_EXPORT\";\n }\n ? {\n json: string;\n count: number;\n }\n : T extends {\n type: \"SETTINGS_GET\";\n }\n ? {\n settings: unknown;\n }\n : undefined\n : unknown // For custom messages outside ExtensionMessage, require phantom type\n : unknown; // Fallback for messages without type field\n\n// Message handler mapping (which context handles which message)\n// Can be a single context or an array for multi-target routing\nexport type MessageHandler = {\n DOM_QUERY: \"content\";\n DOM_UPDATE: \"content\";\n DOM_INSERT: \"content\";\n DOM_REMOVE: \"content\";\n\n PAGE_EVAL: \"page\";\n PAGE_GET_VAR: \"page\";\n PAGE_CALL_FN: \"page\";\n PAGE_SET_VAR: \"page\";\n\n API_REQUEST: \"background\";\n API_BATCH: \"background\";\n\n CLIPBOARD_WRITE: \"offscreen\";\n CLIPBOARD_WRITE_HTML: \"offscreen\";\n CLIPBOARD_WRITE_RICH: \"offscreen\";\n CLIPBOARD_READ: \"offscreen\";\n\n CONTEXT_MENU_CLICKED: \"background\";\n CONTEXT_MENU_CREATE: \"background\";\n CONTEXT_MENU_REMOVE: \"background\";\n\n STATE_SYNC: Context[]; // Broadcast to all contexts\n\n TAB_QUERY: \"background\";\n TAB_GET_CURRENT: \"background\";\n TAB_RELOAD: \"background\";\n\n DEVTOOLS_INSPECT_ELEMENT: \"content\";\n DEVTOOLS_LOG: \"background\";\n\n LOG: \"background\";\n LOGS_GET: \"background\";\n LOGS_CLEAR: \"background\";\n LOGS_EXPORT: \"background\";\n};\n\n// Routed message envelope\nexport type RoutedMessage<T extends BaseMessage = ExtensionMessage> = {\n id: string; // Correlation ID (UUID)\n source: Context; // Which context sent it\n targets: Context[]; // Which contexts should receive this (can be multiple)\n tabId?: number; // Required for per-tab contexts\n timestamp: number; // When it was sent\n payload: T; // The actual message\n};\n\n// Routed response envelope\nexport type RoutedResponse<T extends BaseMessage = ExtensionMessage> = {\n id: string; // Matches request ID\n success: boolean; // Whether operation succeeded\n data?: MessageResponse<T>; // Response data\n error?: string; // Error message if failed\n timestamp: number; // When response was sent\n};\n",
15
15
  "// Custom error classes for the extension\n\nimport type { LoggerAdapter } from \"../adapters/logger.adapter\";\n\n/**\n * Base error class for all extension errors\n */\nexport class ExtensionError extends Error {\n constructor(\n message: string,\n public readonly code: string,\n public readonly context?: Record<string, unknown>\n ) {\n super(message);\n this.name = this.constructor.name;\n Error.captureStackTrace?.(this, this.constructor);\n }\n}\n\n/**\n * Error thrown when a message times out\n */\nexport class TimeoutError extends ExtensionError {\n constructor(\n message: string,\n public readonly timeoutMs: number,\n context?: Record<string, unknown>\n ) {\n super(message, \"TIMEOUT_ERROR\", { ...context, timeoutMs });\n }\n}\n\n/**\n * Error thrown when a connection is lost or unavailable\n */\nexport class ConnectionError extends ExtensionError {\n constructor(message: string, context?: Record<string, unknown>) {\n super(message, \"CONNECTION_ERROR\", context);\n }\n}\n\n/**\n * Error thrown by MessageRouter\n */\nexport class MessageRouterError extends ExtensionError {\n constructor(message: string, context?: Record<string, unknown>) {\n super(message, \"MESSAGE_ROUTER_ERROR\", context);\n }\n}\n\n/**\n * Error thrown when a message handler fails\n */\nexport class HandlerError extends ExtensionError {\n constructor(\n message: string,\n public readonly messageType: string,\n context?: Record<string, unknown>\n ) {\n super(message, \"HANDLER_ERROR\", { ...context, messageType });\n }\n}\n\n/**\n * Error thrown when an API request fails\n */\nexport class APIError extends ExtensionError {\n constructor(\n message: string,\n public readonly statusCode: number,\n context?: Record<string, unknown>\n ) {\n super(message, \"API_ERROR\", { ...context, statusCode });\n }\n}\n\n/**\n * Error thrown when offscreen document operations fail\n */\nexport class OffscreenError extends ExtensionError {\n constructor(message: string, context?: Record<string, unknown>) {\n super(message, \"OFFSCREEN_ERROR\", context);\n }\n}\n\n/**\n * Error utility for logging and throwing errors\n */\nexport class ErrorHandler {\n constructor(private logger: LoggerAdapter) {}\n\n /**\n * Log an error and then throw it\n */\n throw(error: ExtensionError): never {\n this.logger.error(error.message, error, error.context);\n throw error;\n }\n\n /**\n * Log an error and return it (for Promise.reject)\n */\n reject(error: ExtensionError): ExtensionError {\n this.logger.error(error.message, error, error.context);\n return error;\n }\n\n /**\n * Wrap an unknown error in an ExtensionError\n */\n wrap(\n error: unknown,\n message: string,\n code: string,\n context?: Record<string, unknown>\n ): ExtensionError {\n const originalError = error instanceof Error ? error : new Error(String(error));\n const wrappedError = new ExtensionError(`${message}: ${originalError.message}`, code, {\n ...context,\n originalError: originalError.message,\n originalStack: originalError.stack,\n });\n\n // Preserve original stack if available\n if (originalError.stack) {\n wrappedError.stack = originalError.stack;\n }\n\n this.logger.error(wrappedError.message, wrappedError, wrappedError.context);\n return wrappedError;\n }\n}\n",
16
- "/**\n * Context-Specific Helpers\n *\n * Provides context-specific utility methods to make common patterns easier.\n */\n\nimport type { ExtensionAdapters } from \"../adapters\";\n\n/**\n * View types for extension views.\n * This is a local type definition since chrome.extension.ViewType is deprecated.\n */\ntype ExtensionViewType = \"tab\" | \"popup\" | \"notification\";\n\n/**\n * Helpers for content script context.\n * Content scripts have access to the DOM and page context.\n */\nexport interface ContentScriptHelpers {\n /**\n * Get basic page information.\n */\n getPageInfo(): {\n url: string;\n title: string;\n host: string;\n pathname: string;\n readyState: DocumentReadyState;\n };\n\n /**\n * Query DOM elements (returns serializable data).\n */\n queryElements(selector: string): Array<{\n tagName: string;\n id: string;\n className: string;\n textContent: string;\n }>;\n\n /**\n * Get page metadata (meta tags).\n */\n getPageMetadata(): Record<string, string>;\n\n /**\n * Inject CSS into the page.\n */\n injectCSS(css: string): void;\n\n /**\n * Remove injected CSS.\n */\n removeCSS(styleId: string): void;\n}\n\nexport function createContentScriptHelpers(): ContentScriptHelpers {\n return {\n getPageInfo() {\n return {\n url: window.location.href,\n title: document.title,\n host: window.location.host,\n pathname: window.location.pathname,\n readyState: document.readyState,\n };\n },\n\n queryElements(selector: string) {\n const elements = document.querySelectorAll(selector);\n return Array.from(elements).map((el) => ({\n tagName: el.tagName,\n id: el.id,\n className: el.className,\n textContent: el.textContent?.slice(0, 100) || \"\",\n }));\n },\n\n getPageMetadata() {\n const metadata: Record<string, string> = {};\n const metaTags = document.querySelectorAll(\"meta\");\n\n for (const tag of Array.from(metaTags)) {\n const name = tag.getAttribute(\"name\") || tag.getAttribute(\"property\");\n const content = tag.getAttribute(\"content\");\n\n if (name && content) {\n metadata[name] = content;\n }\n }\n\n return metadata;\n },\n\n injectCSS(css: string) {\n const styleId = `ext-injected-${Date.now()}`;\n const style = document.createElement(\"style\");\n style.id = styleId;\n style.textContent = css;\n document.head.appendChild(style);\n },\n\n removeCSS(styleId: string) {\n const style = document.getElementById(styleId);\n if (style) {\n style.remove();\n }\n },\n };\n}\n\n/**\n * Helpers for DevTools panel context.\n * DevTools can inspect the page and access Chrome DevTools APIs.\n */\nexport interface DevToolsHelpers {\n /**\n * Get the ID of the tab being inspected.\n */\n get inspectedTabId(): number | undefined;\n\n /**\n * Execute code in the inspected page context.\n */\n evalInPage<T = unknown>(code: string): Promise<T>;\n\n /**\n * Get page resource content (HTML, CSS, JS files).\n */\n getPageResource(url: string): Promise<string>;\n\n /**\n * Reload the inspected page.\n */\n reloadInspectedPage(options?: { ignoreCache?: boolean; userAgent?: string }): void;\n}\n\nexport function createDevToolsHelpers(): DevToolsHelpers {\n return {\n get inspectedTabId() {\n return chrome.devtools?.inspectedWindow?.tabId;\n },\n\n evalInPage<T = unknown>(code: string): Promise<T> {\n return new Promise((resolve, reject) => {\n if (!chrome.devtools?.inspectedWindow) {\n reject(new Error(\"DevTools inspectedWindow not available\"));\n return;\n }\n\n chrome.devtools.inspectedWindow.eval(code, (result, error) => {\n if (error) {\n reject(new Error(error.isException ? error.value : \"Execution error\"));\n } else {\n resolve(result as T);\n }\n });\n });\n },\n\n getPageResource(url: string): Promise<string> {\n return new Promise((resolve, reject) => {\n if (!chrome.devtools?.inspectedWindow) {\n reject(new Error(\"DevTools inspectedWindow not available\"));\n return;\n }\n\n chrome.devtools.inspectedWindow.getResources((resources) => {\n const resource = resources.find((r) => r.url === url);\n if (!resource) {\n reject(new Error(`Resource not found: ${url}`));\n return;\n }\n\n resource.getContent((content, encoding) => {\n if (encoding === \"base64\") {\n resolve(atob(content));\n } else {\n resolve(content);\n }\n });\n });\n });\n },\n\n reloadInspectedPage(options = {}) {\n if (!chrome.devtools?.inspectedWindow) {\n console.warn(\"DevTools inspectedWindow not available\");\n return;\n }\n\n chrome.devtools.inspectedWindow.reload(options);\n },\n };\n}\n\n/**\n * Helpers for popup context.\n * Popups are short-lived UI windows.\n */\nexport interface PopupHelpers {\n /**\n * Get current active tab.\n */\n getCurrentTab(): Promise<chrome.tabs.Tab | undefined>;\n\n /**\n * Close the popup programmatically.\n */\n closePopup(): void;\n\n /**\n * Set popup dimensions.\n */\n setDimensions(width: number, height: number): void;\n}\n\nexport function createPopupHelpers(adapters: ExtensionAdapters): PopupHelpers {\n return {\n async getCurrentTab() {\n const tabs = await adapters.tabs.query({ active: true, currentWindow: true });\n return tabs[0];\n },\n\n closePopup() {\n window.close();\n },\n\n setDimensions(width: number, height: number) {\n document.body.style.width = `${width}px`;\n document.body.style.height = `${height}px`;\n },\n };\n}\n\n/**\n * Helpers for options page context.\n * Options pages are full-page settings interfaces.\n */\nexport interface OptionsHelpers {\n /**\n * Open extension in new tab (for external links).\n */\n openInNewTab(path: string): void;\n\n /**\n * Show save confirmation message.\n */\n showSaveConfirmation(message?: string, duration?: number): void;\n\n /**\n * Show error message.\n */\n showError(message: string, duration?: number): void;\n}\n\nexport function createOptionsHelpers(adapters: ExtensionAdapters): OptionsHelpers {\n return {\n openInNewTab(path: string) {\n adapters.tabs.create({ url: path });\n },\n\n showSaveConfirmation(message = \"Settings saved!\", duration = 3000) {\n const notification = document.createElement(\"div\");\n notification.textContent = message;\n notification.style.cssText = `\n position: fixed;\n top: 20px;\n right: 20px;\n background: #4caf50;\n color: white;\n padding: 12px 24px;\n border-radius: 4px;\n box-shadow: 0 2px 8px rgba(0,0,0,0.2);\n z-index: 10000;\n animation: slideIn 0.3s ease;\n `;\n\n document.body.appendChild(notification);\n\n setTimeout(() => {\n notification.style.animation = \"slideOut 0.3s ease\";\n setTimeout(() => notification.remove(), 300);\n }, duration);\n },\n\n showError(message: string, duration = 5000) {\n const notification = document.createElement(\"div\");\n notification.textContent = message;\n notification.style.cssText = `\n position: fixed;\n top: 20px;\n right: 20px;\n background: #f44336;\n color: white;\n padding: 12px 24px;\n border-radius: 4px;\n box-shadow: 0 2px 8px rgba(0,0,0,0.2);\n z-index: 10000;\n animation: slideIn 0.3s ease;\n `;\n\n document.body.appendChild(notification);\n\n setTimeout(() => {\n notification.style.animation = \"slideOut 0.3s ease\";\n setTimeout(() => notification.remove(), 300);\n }, duration);\n },\n };\n}\n\n/**\n * Helpers for side panel context.\n * Side panels are persistent companion interfaces.\n */\nexport interface SidePanelHelpers {\n /**\n * Get current active tab.\n */\n getCurrentTab(): Promise<chrome.tabs.Tab | undefined>;\n\n /**\n * Check if side panel is currently visible.\n */\n isVisible(): boolean;\n\n /**\n * Set side panel width (if supported by browser).\n */\n setWidth(width: number): void;\n}\n\nexport function createSidePanelHelpers(adapters: ExtensionAdapters): SidePanelHelpers {\n return {\n async getCurrentTab() {\n const tabs = await adapters.tabs.query({ active: true, currentWindow: true });\n return tabs[0];\n },\n\n isVisible() {\n return document.visibilityState === \"visible\";\n },\n\n setWidth(width: number) {\n document.body.style.width = `${width}px`;\n },\n };\n}\n\n/**\n * Helpers for background context.\n * Background scripts coordinate extension behavior.\n */\nexport interface BackgroundHelpers {\n /**\n * Get all open tabs.\n */\n getAllTabs(): Promise<chrome.tabs.Tab[]>;\n\n /**\n * Get extension views (popup, options, devtools, etc).\n */\n getExtensionViews(type?: ExtensionViewType): Window[];\n\n /**\n * Open options page.\n */\n openOptionsPage(): void;\n\n /**\n * Set extension badge.\n */\n setBadge(text: string, color?: string): void;\n\n /**\n * Clear extension badge.\n */\n clearBadge(): void;\n}\n\nexport function createBackgroundHelpers(adapters: ExtensionAdapters): BackgroundHelpers {\n return {\n async getAllTabs() {\n return adapters.tabs.query({});\n },\n\n getExtensionViews(type?: ExtensionViewType) {\n return chrome.extension.getViews(type ? { type } : undefined);\n },\n\n openOptionsPage() {\n adapters.runtime.openOptionsPage();\n },\n\n setBadge(text: string, color = \"#f44336\") {\n chrome.action.setBadgeText({ text });\n chrome.action.setBadgeBackgroundColor({ color });\n },\n\n clearBadge() {\n chrome.action.setBadgeText({ text: \"\" });\n },\n };\n}\n",
16
+ "/**\n * Context-Specific Helpers\n *\n * Provides context-specific utility methods to make common patterns easier.\n */\n\nimport type { ExtensionAdapters } from \"../adapters\";\n\n/**\n * View types for extension views.\n * This is a local type definition since chrome.extension.ViewType is deprecated.\n */\ntype ExtensionViewType = \"tab\" | \"popup\" | \"notification\";\n\n/**\n * Helpers for content script context.\n * Content scripts have access to the DOM and page context.\n */\nexport interface ContentScriptHelpers {\n /**\n * Get basic page information.\n */\n getPageInfo(): {\n url: string;\n title: string;\n host: string;\n pathname: string;\n readyState: DocumentReadyState;\n };\n\n /**\n * Query DOM elements (returns serializable data).\n */\n queryElements(selector: string): Array<{\n tagName: string;\n id: string;\n className: string;\n textContent: string;\n }>;\n\n /**\n * Get page metadata (meta tags).\n */\n getPageMetadata(): Record<string, string>;\n\n /**\n * Inject CSS into the page.\n */\n injectCSS(css: string): void;\n\n /**\n * Remove injected CSS.\n */\n removeCSS(styleId: string): void;\n}\n\nexport function createContentScriptHelpers(): ContentScriptHelpers {\n return {\n getPageInfo() {\n return {\n url: window.location.href,\n title: document.title,\n host: window.location.host,\n pathname: window.location.pathname,\n readyState: document.readyState,\n };\n },\n\n queryElements(selector: string) {\n const elements = document.querySelectorAll(selector);\n return Array.from(elements).map((el) => ({\n tagName: el.tagName,\n id: el.id,\n className: el.className,\n textContent: el.textContent?.slice(0, 100) || \"\",\n }));\n },\n\n getPageMetadata() {\n const metadata: Record<string, string> = {};\n const metaTags = document.querySelectorAll(\"meta\");\n\n for (const tag of Array.from(metaTags)) {\n const name = tag.getAttribute(\"name\") || tag.getAttribute(\"property\");\n const content = tag.getAttribute(\"content\");\n\n if (name && content) {\n metadata[name] = content;\n }\n }\n\n return metadata;\n },\n\n injectCSS(css: string) {\n const styleId = `ext-injected-${Date.now()}`;\n const style = document.createElement(\"style\");\n style.id = styleId;\n style.textContent = css;\n document.head.appendChild(style);\n },\n\n removeCSS(styleId: string) {\n const style = document.getElementById(styleId);\n if (style) {\n style.remove();\n }\n },\n };\n}\n\n/**\n * Helpers for DevTools panel context.\n * DevTools can inspect the page and access Chrome DevTools APIs.\n */\nexport interface DevToolsHelpers {\n /**\n * Get the ID of the tab being inspected.\n */\n get inspectedTabId(): number | undefined;\n\n /**\n * Execute code in the inspected page context.\n */\n evalInPage<T = unknown>(code: string): Promise<T>;\n\n /**\n * Get page resource content (HTML, CSS, JS files).\n */\n getPageResource(url: string): Promise<string>;\n\n /**\n * Reload the inspected page.\n */\n reloadInspectedPage(options?: { ignoreCache?: boolean; userAgent?: string }): void;\n}\n\nexport function createDevToolsHelpers(): DevToolsHelpers {\n return {\n get inspectedTabId() {\n return chrome.devtools?.inspectedWindow?.tabId;\n },\n\n evalInPage<T = unknown>(code: string): Promise<T> {\n return new Promise((resolve, reject) => {\n if (!chrome.devtools?.inspectedWindow) {\n reject(new Error(\"DevTools inspectedWindow not available\"));\n return;\n }\n\n chrome.devtools.inspectedWindow.eval(code, (result, error) => {\n if (error) {\n reject(new Error(error.isException ? error.value : \"Execution error\"));\n } else {\n resolve(result as T);\n }\n });\n });\n },\n\n getPageResource(url: string): Promise<string> {\n return new Promise((resolve, reject) => {\n if (!chrome.devtools?.inspectedWindow) {\n reject(new Error(\"DevTools inspectedWindow not available\"));\n return;\n }\n\n chrome.devtools.inspectedWindow.getResources((resources) => {\n const resource = resources.find((r) => r.url === url);\n if (!resource) {\n reject(new Error(`Resource not found: ${url}`));\n return;\n }\n\n resource.getContent((content, encoding) => {\n if (encoding === \"base64\") {\n resolve(atob(content));\n } else {\n resolve(content);\n }\n });\n });\n });\n },\n\n reloadInspectedPage(options = {}) {\n if (!chrome.devtools?.inspectedWindow) {\n console.warn(\"DevTools inspectedWindow not available\");\n return;\n }\n\n chrome.devtools.inspectedWindow.reload(options);\n },\n };\n}\n\n/**\n * Helpers for popup context.\n * Popups are short-lived UI windows.\n */\nexport interface PopupHelpers {\n /**\n * Get current active tab.\n */\n getCurrentTab(): Promise<chrome.tabs.Tab | undefined>;\n\n /**\n * Close the popup programmatically.\n */\n closePopup(): void;\n\n /**\n * Set popup dimensions.\n */\n setDimensions(width: number, height: number): void;\n}\n\nexport function createPopupHelpers(adapters: ExtensionAdapters): PopupHelpers {\n return {\n async getCurrentTab() {\n const tabs = await adapters.tabs.query({ active: true, currentWindow: true });\n return tabs[0];\n },\n\n closePopup() {\n window.close();\n },\n\n setDimensions(width: number, height: number) {\n document.body.style.width = `${width}px`;\n document.body.style.height = `${height}px`;\n },\n };\n}\n\n/**\n * Helpers for options page context.\n * Options pages are full-page settings interfaces.\n */\nexport interface OptionsHelpers {\n /**\n * Open extension in new tab (for external links).\n */\n openInNewTab(path: string): void;\n\n /**\n * Show save confirmation message.\n */\n showSaveConfirmation(message?: string, duration?: number): void;\n\n /**\n * Show error message.\n */\n showError(message: string, duration?: number): void;\n}\n\nexport function createOptionsHelpers(adapters: ExtensionAdapters): OptionsHelpers {\n return {\n openInNewTab(path: string) {\n adapters.tabs.create({ url: path });\n },\n\n showSaveConfirmation(message = \"Settings saved!\", duration = 3000) {\n const notification = document.createElement(\"div\");\n notification.textContent = message;\n notification.style.cssText = `\n position: fixed;\n top: 20px;\n right: 20px;\n background: #4caf50;\n color: white;\n padding: 12px 24px;\n border-radius: 4px;\n box-shadow: 0 2px 8px rgba(0,0,0,0.2);\n z-index: 10000;\n animation: slideIn 0.3s ease;\n `;\n\n document.body.appendChild(notification);\n\n setTimeout(() => {\n notification.style.animation = \"slideOut 0.3s ease\";\n setTimeout(() => notification.remove(), 300);\n }, duration);\n },\n\n showError(message: string, duration = 5000) {\n const notification = document.createElement(\"div\");\n notification.textContent = message;\n notification.style.cssText = `\n position: fixed;\n top: 20px;\n right: 20px;\n background: #f44336;\n color: white;\n padding: 12px 24px;\n border-radius: 4px;\n box-shadow: 0 2px 8px rgba(0,0,0,0.2);\n z-index: 10000;\n animation: slideIn 0.3s ease;\n `;\n\n document.body.appendChild(notification);\n\n setTimeout(() => {\n notification.style.animation = \"slideOut 0.3s ease\";\n setTimeout(() => notification.remove(), 300);\n }, duration);\n },\n };\n}\n\n/**\n * Helpers for side panel context.\n * Side panels are persistent companion interfaces.\n */\nexport interface SidePanelHelpers {\n /**\n * Get current active tab.\n */\n getCurrentTab(): Promise<chrome.tabs.Tab | undefined>;\n\n /**\n * Check if side panel is currently visible.\n */\n isVisible(): boolean;\n\n /**\n * Set side panel width (if supported by browser).\n */\n setWidth(width: number): void;\n}\n\nexport function createSidePanelHelpers(adapters: ExtensionAdapters): SidePanelHelpers {\n return {\n async getCurrentTab() {\n const tabs = await adapters.tabs.query({ active: true, currentWindow: true });\n return tabs[0];\n },\n\n isVisible() {\n return document.visibilityState === \"visible\";\n },\n\n setWidth(width: number) {\n document.body.style.width = `${width}px`;\n },\n };\n}\n\n/**\n * Helpers for background context.\n * Background scripts coordinate extension behavior.\n */\nexport interface BackgroundHelpers {\n /**\n * Get all open tabs.\n */\n getAllTabs(): Promise<chrome.tabs.Tab[]>;\n\n /**\n * Get extension views (popup, options, devtools, etc).\n */\n getExtensionViews(type?: ExtensionViewType): Window[];\n\n /**\n * Open options page.\n */\n openOptionsPage(): void;\n\n /**\n * Set extension badge.\n */\n setBadge(text: string, color?: string): void;\n\n /**\n * Clear extension badge.\n */\n clearBadge(): void;\n}\n\nexport function createBackgroundHelpers(adapters: ExtensionAdapters): BackgroundHelpers {\n return {\n async getAllTabs() {\n return adapters.tabs.query({});\n },\n\n getExtensionViews(type?: ExtensionViewType) {\n return chrome.extension.getViews(\n type && (type === \"popup\" || type === \"tab\") ? { type } : undefined\n );\n },\n\n openOptionsPage() {\n adapters.runtime.openOptionsPage();\n },\n\n setBadge(text: string, color = \"#f44336\") {\n chrome.action.setBadgeText({ text });\n chrome.action.setBadgeBackgroundColor({ color });\n },\n\n clearBadge() {\n chrome.action.setBadgeText({ text: \"\" });\n },\n };\n}\n",
17
17
  "// Runtime handler execution tracking to prevent double-execution bugs\n// Only active in development mode, zero runtime cost in production\n\nexport class HandlerExecutionTracker {\n private executions = new Map<string, Map<string, number>>(); // messageId → handlerType → count\n private readonly isDevelopment: boolean;\n\n constructor() {\n // Check if we're in development mode or test mode\n this.isDevelopment =\n typeof process !== \"undefined\" &&\n (process.env?.NODE_ENV === \"development\" || process.env?.NODE_ENV === \"test\");\n }\n\n /**\n * Track a handler execution. Throws error if handler executes multiple times\n * for the same message ID.\n *\n * @param messageId - Unique message identifier\n * @param handlerType - Handler type (e.g., 'TODO_ADD')\n * @throws Error if handler already executed for this message\n */\n track(messageId: string, handlerType: string): void {\n if (!this.isDevelopment) return;\n\n let handlerCounts = this.executions.get(messageId);\n if (!handlerCounts) {\n handlerCounts = new Map();\n this.executions.set(messageId, handlerCounts);\n }\n\n const count = (handlerCounts.get(handlerType) || 0) + 1;\n handlerCounts.set(handlerType, count);\n\n if (count > 1) {\n const error = new Error(\n `🔴 DOUBLE EXECUTION DETECTED\\n\\nHandler \"${handlerType}\" executed ${count} times for message ${messageId}.\\n\\nThis indicates multiple chrome.runtime.onMessage listeners are registered.\\nCommon causes:\\n 1. Both MessageBus and MessageRouter registered listeners\\n 2. createBackground() called multiple times\\n 3. Handler registered in multiple places\\n\\nFix: Ensure only ONE listener is registered. In background scripts,\\nuse createBackground() instead of getMessageBus().\\n`\n );\n\n console.error(error);\n\n // Also log the execution trace\n console.error(\"Execution trace for message:\", messageId);\n console.error(Array.from(handlerCounts.entries()));\n\n throw error;\n }\n\n // Cleanup old messages after 5 seconds to prevent memory leak\n setTimeout(() => {\n this.executions.delete(messageId);\n }, 5000);\n }\n\n /**\n * Reset all tracked executions. Useful for testing.\n */\n reset(): void {\n this.executions.clear();\n }\n\n /**\n * Get execution count for a specific message and handler.\n * Useful for testing.\n */\n getExecutionCount(messageId: string, handlerType: string): number {\n return this.executions.get(messageId)?.get(handlerType) || 0;\n }\n}\n\n// Global singleton instance\nexport const globalExecutionTracker = new HandlerExecutionTracker();\n",
18
18
  "// Type-safe message bus for extension communication\n\nimport type { ExtensionAdapters, MessageSender } from \"../adapters\";\nimport { createChromeAdapters } from \"../adapters\";\nimport type {\n BaseMessage,\n Context,\n ExtensionMessage,\n MessageResponse,\n RoutedMessage,\n RoutedResponse,\n} from \"../types/messages\";\nimport { ALL_CONTEXTS } from \"../types/messages\";\nimport type {\n BackgroundHelpers,\n ContentScriptHelpers,\n DevToolsHelpers,\n OptionsHelpers,\n PopupHelpers,\n SidePanelHelpers,\n} from \"./context-specific-helpers\";\nimport {\n createBackgroundHelpers,\n createContentScriptHelpers,\n createDevToolsHelpers,\n createOptionsHelpers,\n createPopupHelpers,\n createSidePanelHelpers,\n} from \"./context-specific-helpers\";\nimport { ConnectionError, ErrorHandler, HandlerError, TimeoutError } from \"./errors\";\nimport { globalExecutionTracker } from \"./handler-execution-tracker\";\n\n// Type guards for runtime message validation\n// Note: These validate structure but can't validate TMessage type at runtime\nexport function isRoutedMessage<TMessage extends BaseMessage = BaseMessage>(\n value: unknown\n): value is RoutedMessage<TMessage> {\n if (typeof value !== \"object\" || value === null) return false;\n // Use 'in' operator for type narrowing - no cast needed\n if (!(\"id\" in value) || !(\"source\" in value) || !(\"targets\" in value) || !(\"payload\" in value)) {\n return false;\n }\n // TypeScript now knows these properties exist\n return (\n typeof value.id === \"string\" &&\n typeof value.source === \"string\" &&\n Array.isArray(value.targets) &&\n typeof value.payload === \"object\" &&\n value.payload !== null\n );\n}\n\nexport function isRoutedResponse<TMessage extends BaseMessage = BaseMessage>(\n value: unknown\n): value is RoutedResponse<TMessage> {\n if (typeof value !== \"object\" || value === null) return false;\n // Use 'in' operator for type narrowing - no cast needed\n if (!(\"id\" in value) || !(\"success\" in value)) {\n return false;\n }\n // TypeScript now knows these properties exist\n return typeof value.id === \"string\" && typeof value.success === \"boolean\";\n}\n\ntype PendingRequest<TMessage extends BaseMessage = ExtensionMessage> = {\n // Accepts the union of all possible response types\n // Type safety is enforced at handler registration (.on) and invocation (send)\n resolve: (value: MessageResponse<TMessage> | undefined) => void;\n reject: (error: Error) => void;\n timestamp: number;\n timeout: NodeJS.Timeout;\n};\n\nexport class MessageBus<TMessage extends BaseMessage = ExtensionMessage> {\n public context: Context;\n public adapters: ExtensionAdapters;\n public helpers:\n | ContentScriptHelpers\n | DevToolsHelpers\n | PopupHelpers\n | OptionsHelpers\n | SidePanelHelpers\n | BackgroundHelpers\n | Record<string, never>;\n public pendingRequests = new Map<string, PendingRequest<TMessage>>();\n // Handlers Map stores arrays of functions with varying signatures\n // Type safety is enforced at registration (.on()) and invocation (send())\n // biome-ignore lint/complexity/noBannedTypes: Function type needed for dynamic handler map\n private handlers = new Map<string, Function[]>();\n private port: ReturnType<ExtensionAdapters[\"runtime\"][\"connect\"]> | null = null;\n private errorHandler: ErrorHandler;\n private userErrorHandlers: Array<(error: Error, bus: MessageBus<TMessage>) => void> = [];\n public messageListener:\n | ((\n message: unknown,\n sender: MessageSender,\n sendResponse: (response: unknown) => void\n ) => boolean)\n | null = null;\n\n constructor(\n context: Context,\n adapters?: ExtensionAdapters,\n options?: { skipListenerSetup?: boolean }\n ) {\n this.context = context;\n this.adapters = adapters || createChromeAdapters(context);\n this.errorHandler = new ErrorHandler(this.adapters.logger);\n this.helpers = this.createContextHelpers();\n\n // Skip listener setup if MessageRouter will handle it\n if (!options?.skipListenerSetup) {\n this.setupListeners();\n }\n }\n\n /**\n * Send a message with type safety.\n * Response type is inferred from message type, though TypeScript requires\n * the return type to be widened due to Map storage limitations.\n * Runtime type safety is ensured by handler registration and invocation.\n */\n async send<T extends TMessage>(\n payload: T,\n options?: {\n target?: Context | Context[];\n tabId?: number;\n timeout?: number;\n }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n const id = crypto.randomUUID();\n\n // For custom messages (not ExtensionMessage), targets must be explicitly provided\n let targets: Context[];\n if (options?.target) {\n // Handle single target from options\n if (Array.isArray(options.target)) {\n targets = options.target;\n } else {\n targets = [options.target];\n }\n } else {\n const inferredTarget = this.inferTarget(payload.type);\n if (!inferredTarget) {\n throw new Error(\n `Message type \"${payload.type}\" is not a framework message. Please provide explicit 'target' option.`\n );\n }\n // inferredTarget can be a single context or an array\n targets = Array.isArray(inferredTarget) ? inferredTarget : [inferredTarget];\n }\n\n const message: RoutedMessage<T> = {\n id,\n source: this.context,\n targets,\n ...(options?.tabId !== undefined && { tabId: options.tabId }),\n timestamp: Date.now(),\n payload,\n };\n\n return new Promise<MessageResponse<T> | undefined>((resolve, reject) => {\n const timeoutMs = options?.timeout || 5000;\n const timeout = setTimeout(() => {\n this.pendingRequests.delete(id);\n const error = new TimeoutError(`Message timeout: ${payload.type}`, timeoutMs, {\n messageType: payload.type,\n targets,\n });\n this.notifyErrorHandlers(error);\n reject(this.errorHandler.reject(error));\n }, timeoutMs);\n\n this.pendingRequests.set(id, {\n resolve: (value) => {\n clearTimeout(timeout);\n resolve(value);\n },\n reject: (error) => {\n clearTimeout(timeout);\n reject(error);\n },\n timestamp: Date.now(),\n timeout,\n });\n\n // Send via appropriate channel\n this.sendMessage(message);\n });\n }\n\n /**\n * Broadcast message to all contexts.\n * Used for state synchronization.\n */\n broadcast<T extends TMessage>(payload: T): void {\n const message: RoutedMessage<T> = {\n id: crypto.randomUUID(),\n source: this.context,\n targets: ALL_CONTEXTS,\n timestamp: Date.now(),\n payload,\n };\n\n this.sendMessage(message);\n }\n\n /**\n * Register a typed message handler.\n * Handler signature is enforced based on message type.\n * Multiple handlers can be registered for the same message type.\n */\n on<T extends TMessage[\"type\"]>(\n type: T,\n handler: (\n payload: Extract<TMessage, { type: T }>,\n message: RoutedMessage<Extract<TMessage, { type: T }>>\n ) =>\n | Promise<MessageResponse<Extract<TMessage, { type: T }>>>\n | MessageResponse<Extract<TMessage, { type: T }>>\n ): void {\n // Store handler with runtime type safety\n // TypeScript can't verify cross-boundary type safety through the Map storage,\n // but the .on() signature ensures the handler matches the message type\n const existing = this.handlers.get(type) || [];\n existing.push(handler);\n this.handlers.set(type, existing);\n }\n\n /**\n * Register multiple message handlers at once.\n * Reduces boilerplate when defining many handlers.\n *\n * @example\n * ```typescript\n * bus.registerHandlers({\n * 'MY_MESSAGE': async (payload) => ({ success: true }),\n * 'ANOTHER_MESSAGE': async (payload) => ({ data: payload }),\n * })\n * ```\n */\n // biome-ignore lint/complexity/noBannedTypes: Need to accept user-defined message types beyond ExtensionMessage\n registerHandlers(handlers: Record<string, Function | undefined>): void {\n for (const [type, handler] of Object.entries(handlers)) {\n if (handler) {\n const existing = this.handlers.get(type) || [];\n existing.push(handler);\n this.handlers.set(type, existing);\n }\n }\n }\n\n /**\n * Register a global error handler.\n * Called when errors occur during message handling.\n *\n * @example\n * ```typescript\n * bus.onError((error, bus) => {\n * console.error(`[${bus.context}] Error:`, error)\n * // Report to error tracking service\n * })\n * ```\n */\n onError(handler: (error: Error, bus: MessageBus<TMessage>) => void): void {\n this.userErrorHandlers.push(handler);\n }\n\n /**\n * Send message to background context.\n * Explicit routing API for better DX.\n *\n * @example\n * ```typescript\n * const result = await bus.sendToBackground({ type: 'GET_SETTINGS' })\n * ```\n */\n async sendToBackground<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"background\" });\n }\n\n /**\n * Send message to a specific content script.\n *\n * @example\n * ```typescript\n * const result = await bus.sendToContentScript(tabId, { type: 'ANALYZE_PAGE' })\n * ```\n */\n async sendToContentScript<T extends TMessage>(\n tabId: number,\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"content\", tabId });\n }\n\n /**\n * Send message to all tabs.\n * Useful for broadcasting updates to all content scripts.\n *\n * @example\n * ```typescript\n * await bus.sendToAllTabs({ type: 'REFRESH_UI' })\n * ```\n */\n async sendToAllTabs<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n Array<\n | MessageResponse<\n Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>\n >\n | undefined\n >\n > {\n const tabs = await this.adapters.tabs.query({});\n return Promise.all(\n tabs.map((tab) =>\n tab.id ? this.sendToContentScript(tab.id, payload, options) : Promise.resolve(undefined)\n )\n );\n }\n\n /**\n * Send message to popup context.\n *\n * @example\n * ```typescript\n * await bus.sendToPopup({ type: 'UPDATE_UI', data: newData })\n * ```\n */\n async sendToPopup<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"popup\" });\n }\n\n /**\n * Send message to options page.\n *\n * @example\n * ```typescript\n * await bus.sendToOptions({ type: 'SETTINGS_UPDATED' })\n * ```\n */\n async sendToOptions<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"options\" });\n }\n\n /**\n * Send message to devtools panel.\n *\n * @example\n * ```typescript\n * await bus.sendToDevTools({ type: 'INSPECTION_DATA', data: pageData })\n * ```\n */\n async sendToDevTools<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"devtools\" });\n }\n\n /**\n * Send message to side panel.\n *\n * @example\n * ```typescript\n * await bus.sendToSidePanel({ type: 'UPDATE_ACTIVITY_LOG' })\n * ```\n */\n async sendToSidePanel<T extends TMessage>(\n payload: T,\n options?: { timeout?: number }\n ): Promise<\n | MessageResponse<Extract<TMessage, { type: T extends { type: infer TType } ? TType : never }>>\n | undefined\n > {\n return this.send(payload, { ...options, target: \"sidepanel\" });\n }\n\n /**\n * Connect with long-lived port.\n * Used for persistent connections (DevTools, Content Scripts).\n */\n connect(name: string): void {\n if (this.port) {\n console.warn(`[${this.context}] Port already connected: ${this.port.name}`);\n return;\n }\n\n this.port = this.adapters.runtime.connect(name);\n\n this.port.onMessage((message: unknown) => {\n if (isRoutedMessage<TMessage>(message) || isRoutedResponse<TMessage>(message)) {\n this.handleMessage(message);\n }\n });\n\n this.port.onDisconnect(() => {\n this.adapters.logger.warn(\"Port disconnected\", {\n context: this.context,\n portName: name,\n });\n this.port = null;\n\n // Reject all pending requests\n for (const [id, pending] of this.pendingRequests.entries()) {\n const error = new ConnectionError(\"Port disconnected\", {\n context: this.context,\n portName: name,\n requestId: id,\n });\n this.notifyErrorHandlers(error);\n pending.reject(this.errorHandler.reject(error));\n clearTimeout(pending.timeout);\n this.pendingRequests.delete(id);\n }\n });\n }\n\n /**\n * Disconnect port if connected.\n */\n disconnect(): void {\n if (this.port) {\n this.port.disconnect();\n this.port = null;\n }\n }\n\n /**\n * Remove all handlers and clean up.\n */\n destroy(): void {\n this.disconnect();\n this.handlers.clear();\n\n // Clear all pending requests\n for (const pending of this.pendingRequests.values()) {\n clearTimeout(pending.timeout);\n }\n this.pendingRequests.clear();\n\n // Remove message listener to prevent leaks\n if (this.messageListener) {\n this.adapters.runtime.removeMessageListener(this.messageListener);\n }\n }\n\n private setupListeners(): void {\n // Listen for one-off messages via chrome.runtime.sendMessage\n this.messageListener = (\n message: unknown,\n sender: unknown,\n sendResponse: (response: unknown) => void\n ) => {\n if (isRoutedMessage<TMessage>(message) || isRoutedResponse<TMessage>(message)) {\n this.handleMessage(message, sender)\n .then((response) => sendResponse(response))\n .catch((error) => {\n sendResponse({ success: false, error: error.message });\n });\n }\n return true; // Indicates async response\n };\n this.adapters.runtime.onMessage(this.messageListener);\n\n // Content/Page script window messaging\n if (this.context === \"content\" || this.context === \"page\") {\n this.adapters.window.addEventListener(\"message\", (event: MessageEvent) => {\n if (event.source !== window) return;\n if (event.data?.__extensionMessage) {\n this.handleMessage(event.data.message);\n }\n });\n }\n }\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Message handling requires routing logic for different message types\n public async handleMessage(\n message: RoutedMessage<TMessage> | RoutedResponse<TMessage>,\n _sender?: unknown\n ): Promise<unknown> {\n // Handle response to our request\n if (\"success\" in message) {\n const pending = this.pendingRequests.get(message.id);\n if (pending) {\n this.pendingRequests.delete(message.id);\n clearTimeout(pending.timeout);\n\n if (message.success) {\n // Message data is typed as MessageResponse<TMessage> from RoutedResponse\n pending.resolve(message.data ?? undefined);\n } else {\n const error = new HandlerError(message.error || \"Unknown error\", \"unknown\", {\n messageId: message.id,\n });\n this.notifyErrorHandlers(error);\n pending.reject(this.errorHandler.reject(error));\n }\n }\n return;\n }\n\n // Ignore messages not targeted at us\n if (!message.targets.includes(this.context)) {\n // If we're background, we need to route it\n if (this.context === \"background\") {\n return; // Routing handled elsewhere\n }\n return;\n }\n\n // Handle incoming request\n const handlers = this.handlers.get(message.payload.type);\n if (!handlers || handlers.length === 0) {\n // For multi-target messages, don't warn if we have no handler\n if (message.targets.length === 1) {\n console.warn(`[${this.context}] No handler for message type: ${message.payload.type}`);\n }\n return { success: false, error: \"No handler\" };\n }\n\n // For multi-target messages (including broadcasts), call all handlers (don't send responses)\n if (message.targets.length > 1) {\n try {\n // Track execution to detect double-handler invocation\n globalExecutionTracker.track(message.id, message.payload.type);\n\n await Promise.all(handlers.map((handler) => handler(message.payload, message)));\n return { success: true, data: undefined, timestamp: Date.now() };\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n timestamp: Date.now(),\n };\n }\n }\n\n // For LOG messages, call all handlers but still send response (for backwards compat)\n if (message.payload.type === \"LOG\") {\n try {\n // Track execution to detect double-handler invocation\n globalExecutionTracker.track(message.id, message.payload.type);\n\n await Promise.all(handlers.map((handler) => handler(message.payload, message)));\n const response: RoutedResponse<TMessage> = {\n id: message.id,\n success: true,\n timestamp: Date.now(),\n };\n this.sendResponse(message, response);\n return response;\n } catch (error) {\n const response: RoutedResponse<TMessage> = {\n id: message.id,\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n timestamp: Date.now(),\n };\n this.sendResponse(message, response);\n return response;\n }\n }\n\n // For other targeted messages, call first handler and send response\n try {\n // Track execution to detect double-handler invocation\n globalExecutionTracker.track(message.id, message.payload.type);\n\n // We've already checked handlers.length > 0 above, so handlers[0] exists\n const handler = handlers[0];\n if (!handler) {\n throw new Error(`Handler not found for ${message.payload.type}`);\n }\n const data = await handler(message.payload, message);\n\n const response: RoutedResponse<TMessage> = {\n id: message.id,\n success: true,\n data,\n timestamp: Date.now(),\n };\n\n this.sendResponse(message, response);\n return response;\n } catch (error) {\n const response: RoutedResponse<TMessage> = {\n id: message.id,\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n timestamp: Date.now(),\n };\n\n this.sendResponse(message, response);\n return response;\n }\n }\n\n public sendMessage<T extends TMessage = TMessage>(message: RoutedMessage<T>): void {\n if (this.context === \"content\" && message.targets.includes(\"page\")) {\n // Content → Page via window.postMessage\n this.adapters.window.postMessage({ __extensionMessage: true, message }, \"*\");\n } else if (this.context === \"page\") {\n // Page → Content via window.postMessage\n this.adapters.window.postMessage({ __extensionMessage: true, message }, \"*\");\n } else if (this.port) {\n // Use long-lived port if connected (devtools, content, popup, options)\n this.port.postMessage(message);\n } else {\n // Use chrome.runtime.sendMessage (fallback for unconnected contexts)\n this.adapters.runtime.sendMessage(message);\n }\n }\n\n private sendResponse(request: RoutedMessage<TMessage>, response: RoutedResponse<TMessage>): void {\n if (this.context === \"content\" && request.source === \"page\") {\n // Content → Page response\n this.adapters.window.postMessage({ __extensionMessage: true, message: response }, \"*\");\n } else if (this.context === \"page\" && request.source === \"content\") {\n // Page → Content response\n this.adapters.window.postMessage({ __extensionMessage: true, message: response }, \"*\");\n } else if (this.port && (this.context === \"devtools\" || this.context === \"content\")) {\n // Use port for response\n this.port.postMessage(response);\n } else {\n // Use chrome.runtime.sendMessage\n this.adapters.runtime.sendMessage(response);\n }\n }\n\n private inferTarget(type: string): Context | Context[] | undefined {\n const handlers = {\n DOM_QUERY: \"content\",\n DOM_UPDATE: \"content\",\n DOM_INSERT: \"content\",\n DOM_REMOVE: \"content\",\n PAGE_EVAL: \"page\",\n PAGE_GET_VAR: \"page\",\n PAGE_CALL_FN: \"page\",\n PAGE_SET_VAR: \"page\",\n API_REQUEST: \"background\",\n API_BATCH: \"background\",\n CLIPBOARD_WRITE: \"offscreen\",\n CLIPBOARD_WRITE_HTML: \"offscreen\",\n CLIPBOARD_WRITE_RICH: \"offscreen\",\n CLIPBOARD_READ: \"offscreen\",\n CONTEXT_MENU_CREATE: \"background\",\n CONTEXT_MENU_REMOVE: \"background\",\n STATE_SYNC: ALL_CONTEXTS,\n TAB_QUERY: \"background\",\n TAB_GET_CURRENT: \"background\",\n TAB_RELOAD: \"background\",\n LOG: \"background\",\n LOGS_GET: \"background\",\n LOGS_CLEAR: \"background\",\n LOGS_EXPORT: \"background\",\n } as const;\n\n // Helper type guard: narrows string to a key of the object\n function isHandlerKey(key: string): key is keyof typeof handlers {\n return key in handlers;\n }\n\n // Type guard narrows string to known keys\n if (isHandlerKey(type)) {\n // TypeScript now knows type is keyof typeof handlers - no cast needed!\n return handlers[type];\n }\n\n // Unknown message type - caller must provide explicit target\n return undefined;\n }\n\n /**\n * Create context-specific helpers based on current context.\n * @private\n */\n private createContextHelpers():\n | ContentScriptHelpers\n | DevToolsHelpers\n | PopupHelpers\n | OptionsHelpers\n | SidePanelHelpers\n | BackgroundHelpers\n | Record<string, never> {\n switch (this.context) {\n case \"content\":\n return createContentScriptHelpers();\n case \"devtools\":\n return createDevToolsHelpers();\n case \"popup\":\n return createPopupHelpers(this.adapters);\n case \"options\":\n return createOptionsHelpers(this.adapters);\n case \"sidepanel\":\n return createSidePanelHelpers(this.adapters);\n case \"background\":\n return createBackgroundHelpers(this.adapters);\n default:\n return {};\n }\n }\n\n /**\n * Notify all registered error handlers.\n * @private\n */\n private notifyErrorHandlers(error: Error): void {\n for (const handler of this.userErrorHandlers) {\n try {\n handler(error, this);\n } catch (handlerError) {\n console.error(`[${this.context}] Error in error handler:`, handlerError);\n }\n }\n }\n}\n\n/**\n * Create a MessageBus for the given context.\n *\n * IMPORTANT: Only call this ONCE per context in your application.\n * Calling it multiple times will create multiple message listeners, causing\n * handlers to execute multiple times. Store the returned bus and reuse it.\n *\n * For background scripts, use createBackground() instead.\n */\nexport function getMessageBus<TMessage extends BaseMessage = ExtensionMessage>(\n context: Context,\n adapters?: ExtensionAdapters,\n options?: { skipListenerSetup?: boolean }\n): MessageBus<TMessage> {\n return new MessageBus<TMessage>(context, adapters, options);\n}\n",
19
- "// State primitives with optional sync and persistence\n\nimport { type Signal, effect, signal } from \"@preact/signals\";\nimport type { Context } from \"../types/messages\";\nimport { type MessageBus, getMessageBus } from \"./message-bus\";\n\ntype StateEntry<T> = {\n signal: Signal<T>;\n clock: number; // Lamport clock for causal ordering\n loaded: Promise<void>;\n updating: boolean;\n};\n\ntype StateOptions<T = unknown> = {\n bus?: MessageBus; // Custom message bus (for testing)\n debounceMs?: number; // Debounce storage writes\n validator?: (value: unknown) => value is T; // Runtime type validation\n};\n\nconst stateRegistry = new Map<string, StateEntry<unknown>>();\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Context detection requires multiple checks\nfunction getCurrentContext(): Context {\n // Detect current context\n if (typeof chrome !== \"undefined\") {\n if (typeof chrome.devtools !== \"undefined\") {\n return \"devtools\";\n }\n if (typeof chrome.runtime !== \"undefined\") {\n try {\n if (typeof self !== \"undefined\" && \"ServiceWorkerGlobalScope\" in self) {\n return \"background\";\n }\n // biome-ignore lint/suspicious/noEmptyBlockStatements: ServiceWorkerGlobalScope check may fail in some contexts\n } catch {}\n }\n }\n\n if (typeof window !== \"undefined\" && typeof document !== \"undefined\") {\n if (typeof chrome === \"undefined\" || typeof chrome.runtime === \"undefined\") {\n return \"page\";\n }\n\n // Distinguish popup/options/offscreen from content scripts by URL\n if (\n typeof window.location !== \"undefined\" &&\n window.location.protocol === \"chrome-extension:\"\n ) {\n const path = window.location.pathname;\n if (path.includes(\"/popup\")) return \"popup\";\n if (path.includes(\"/options\")) return \"options\";\n if (path.includes(\"/offscreen\")) return \"offscreen\";\n // Could also be a custom extension page, default to content\n }\n\n return \"content\";\n }\n\n return \"background\";\n}\n\n/**\n * Shared state: synced across all contexts AND persisted to storage\n *\n * Uses Lamport clock for conflict resolution. State is automatically:\n * - Loaded from chrome.storage on initialization\n * - Synced to other contexts via broadcast messages\n * - Persisted to chrome.storage on every change\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts (use content script state instead)\n *\n * @param key - Unique identifier for this state (e.g., \"app-settings\")\n * @param initialValue - Default value if nothing is in storage\n * @param options - Optional configuration (bus, debounceMs)\n * @returns Reactive signal that stays in sync across all contexts\n *\n * @example\n * ```typescript\n * // Define once, use everywhere\n * const settings = $sharedState(\"settings\", { theme: \"dark\" })\n *\n * // Changes automatically sync\n * settings.value = { theme: \"light\" }\n * ```\n */\nexport function $sharedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: true,\n persist: true,\n });\n}\n\n/**\n * Synced state: synced across all contexts but NOT persisted\n *\n * State is broadcast to all contexts in real-time but resets on extension reload.\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts\n *\n * @param key - Unique identifier for this state\n * @param initialValue - Default value\n * @param options - Optional configuration\n * @returns Reactive signal synced across contexts (but not persisted)\n *\n * @example\n * ```typescript\n * // Temporary shared state\n * const activeTabId = $syncedState(\"active-tab\", null)\n * ```\n */\nexport function $syncedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: true,\n persist: false,\n });\n}\n\n/**\n * Persisted state: persisted to storage but NOT synced across contexts\n *\n * Each context has its own copy of the state, persisted independently.\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts\n *\n * @param key - Unique identifier (use prefix like \"popup:state\" to avoid collisions)\n * @param initialValue - Default value\n * @param options - Optional configuration\n * @returns Reactive signal persisted to storage (but not synced)\n *\n * @example\n * ```typescript\n * // Each context has its own persisted state\n * const popupState = $persistedState(\"popup:last-panel\", \"home\")\n * const devtoolsState = $persistedState(\"devtools:expanded\", true)\n * ```\n */\nexport function $persistedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: false,\n persist: true,\n });\n}\n\n/**\n * Local state: not synced, not persisted (like regular Preact signal)\n *\n * Simple reactive state that lives only in the current context.\n * Resets on reload or context restart.\n *\n * Available in: all contexts (including page scripts)\n *\n * @param initialValue - Default value\n * @returns Reactive signal (local only)\n *\n * @example\n * ```typescript\n * // Local UI state\n * const isLoading = $state(false)\n * const error = $state<string | null>(null)\n * ```\n */\nexport function $state<T>(initialValue: T): Signal<T> {\n return signal(initialValue);\n}\n\ntype InternalStateOptions<T = unknown> = StateOptions<T> & {\n sync: boolean;\n persist: boolean;\n};\n\n// Deep equality check to prevent redundant updates\nfunction deepEqual(a: unknown, b: unknown): boolean {\n if (a === b) return true;\n if (a == null || b == null) return false;\n if (typeof a !== \"object\" || typeof b !== \"object\") return false;\n\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n\n if (keysA.length !== keysB.length) return false;\n\n for (const key of keysA) {\n if (!keysB.includes(key)) return false;\n if (!deepEqual((a as Record<string, unknown>)[key], (b as Record<string, unknown>)[key]))\n return false;\n }\n\n return true;\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Core state management logic requires coordination of multiple concerns\nfunction createState<T>(key: string, initialValue: T, options: InternalStateOptions<T>): Signal<T> {\n // Return existing signal if already registered\n if (stateRegistry.has(key)) {\n return stateRegistry.get(key)?.signal as Signal<T>;\n }\n\n const currentContext = getCurrentContext();\n\n // Page scripts should not have stateful operations\n // They are execution contexts for content scripts, not independent contexts\n if (currentContext === \"page\" && (options.sync || options.persist)) {\n const stateFn =\n options.sync && options.persist\n ? \"$sharedState\"\n : options.persist\n ? \"$persistedState\"\n : \"$syncedState\";\n\n throw new Error(\n `[web-ext] ${stateFn}() is not available in page context.\\nPage scripts are execution contexts for content scripts and should not maintain state.\\nUse state in the content script instead, or use $state() for local-only state.`\n );\n }\n\n const sig = signal(initialValue);\n\n const entry: StateEntry<T> = {\n signal: sig,\n clock: 0,\n loaded: Promise.resolve(),\n updating: false,\n };\n\n // Lazy bus initialization\n let bus: MessageBus | null = null;\n const getBus = () => {\n if (!bus && typeof chrome !== \"undefined\") {\n bus = options.bus || getMessageBus(currentContext);\n }\n return bus;\n };\n\n // Load from storage if persist is enabled\n if (options.persist) {\n entry.loaded = loadFromStorage(key, sig, entry, getBus(), options.validator);\n }\n\n // Watch for changes after initial load\n entry.loaded.then(() => {\n let debounceTimer: NodeJS.Timeout | null = null;\n let previousValue = sig.value;\n let isFirstRun = true;\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Sync effect requires coordination of multiple state change scenarios\n effect(() => {\n // Skip if update in progress (from incoming message)\n if (entry.updating) return;\n\n const value = sig.value;\n\n // Skip first run (effect fires immediately on registration)\n if (isFirstRun) {\n isFirstRun = false;\n return;\n }\n\n // Skip if value hasn't changed (deep equality check)\n if (deepEqual(value, previousValue)) {\n return;\n }\n\n previousValue = value;\n\n // Increment clock monotonically\n entry.clock++;\n\n const doUpdate = () => {\n // Persist to storage\n if (options.persist) {\n persistToStorage(key, value, entry.clock, getBus());\n }\n\n // Broadcast to other contexts\n if (options.sync) {\n broadcastUpdate(key, value, entry.clock, getBus());\n }\n };\n\n // Debounce if specified\n if (options.debounceMs) {\n if (debounceTimer) clearTimeout(debounceTimer);\n debounceTimer = setTimeout(doUpdate, options.debounceMs);\n } else {\n doUpdate();\n }\n });\n });\n\n // Listen for updates from other contexts (only if sync enabled)\n if (options.sync) {\n const messageBus = getBus();\n if (messageBus) {\n // Auto-connect for contexts that need it (popup, options, devtools)\n // Safe to call multiple times because:\n // - getMessageBus() returns a singleton per context\n // - connect() is idempotent (checks if port exists and returns early)\n // Background doesn't need to connect (it's the hub)\n // Content scripts connect explicitly when needed\n if (\n currentContext === \"popup\" ||\n currentContext === \"options\" ||\n currentContext === \"devtools\"\n ) {\n messageBus.connect(currentContext);\n }\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: State sync requires validation and conflict resolution\n messageBus.on(\"STATE_SYNC\", async (payload) => {\n if (payload.key !== key) return undefined;\n\n const oldClock = entry.clock;\n\n // Lamport clock rule: Always update to max(local, received)\n // This maintains causal ordering even when rejecting updates\n entry.clock = Math.max(entry.clock, payload.clock);\n\n // Only accept value updates if received clock is strictly greater than old local clock\n // This ensures we only apply causally newer updates\n if (payload.clock > oldClock) {\n // Validate incoming value if validator provided\n if (options.validator && !options.validator(payload.value)) {\n console.warn(\n `[web-ext] State \"${key}\": Received invalid value from sync (clock: ${payload.clock})`,\n payload.value\n );\n return undefined;\n }\n\n // Skip redundant updates (deep equality check)\n if (deepEqual(entry.signal.value, payload.value)) {\n return undefined;\n }\n\n applyUpdate(entry, payload.value as T, payload.clock);\n }\n\n return undefined;\n });\n }\n }\n\n stateRegistry.set(key, entry as StateEntry<unknown>);\n return sig;\n}\n\nasync function loadFromStorage<T>(\n key: string,\n sig: Signal<T>,\n entry: StateEntry<T>,\n bus: MessageBus | null,\n validator?: (value: unknown) => value is T\n): Promise<void> {\n if (!bus) return;\n\n try {\n const result = await bus.adapters.storage.get([key, `${key}:clock`]);\n\n if (result[key] !== undefined) {\n const storedValue = result[key];\n\n // Validate stored value if validator provided\n if (validator) {\n if (validator(storedValue)) {\n sig.value = storedValue;\n } else {\n console.warn(\n `[web-ext] State \"${key}\": Stored value failed validation, using initial value`,\n storedValue\n );\n }\n } else {\n sig.value = storedValue as T;\n }\n }\n\n if (result[`${key}:clock`] !== undefined) {\n entry.clock = result[`${key}:clock`] as number;\n }\n } catch (error) {\n console.warn(`[web-ext] Failed to load state from storage: ${key}`, error);\n }\n}\n\nfunction persistToStorage<T>(key: string, value: T, clock: number, bus: MessageBus | null): void {\n if (!bus) return;\n\n try {\n bus.adapters.storage.set({\n [key]: value,\n [`${key}:clock`]: clock,\n });\n } catch (error) {\n console.warn(`Failed to persist state to storage: ${key}`, error);\n }\n}\n\nfunction broadcastUpdate<T>(key: string, value: T, clock: number, bus: MessageBus | null): void {\n if (!bus) return;\n\n try {\n bus.broadcast({\n type: \"STATE_SYNC\",\n key,\n value,\n clock,\n });\n } catch (error) {\n console.warn(`Failed to broadcast state update: ${key}`, error);\n }\n}\n\nfunction applyUpdate<T>(entry: StateEntry<T>, value: T, clock: number): void {\n entry.updating = true;\n entry.signal.value = value;\n entry.clock = clock;\n entry.updating = false;\n}\n\n/**\n * Get state by key (useful for retrieving state without re-creating)\n */\nexport function getStateByKey<T>(key: string): Signal<T> | undefined {\n const entry = stateRegistry.get(key);\n return entry?.signal as Signal<T> | undefined;\n}\n\n/**\n * Clear state registry (useful for testing)\n */\nexport function clearStateRegistry(): void {\n stateRegistry.clear();\n}\n",
20
- "// Shared application state\n\nimport { signal } from \"@preact/signals\";\nimport { $sharedState, $syncedState } from \"../lib/state\";\nimport type { Settings } from \"../types/messages\";\nimport { defaultSettings as _defaultSettings } from \"../types/messages\";\n\n// Re-export for convenience\nexport { defaultSettings } from \"../types/messages\";\n\n// Synced across all contexts, persisted to storage\nexport const settings = $sharedState<Settings>(\"app-settings\", _defaultSettings);\n\n// Synced but not persisted\nexport const currentTab = $syncedState<number | null>(\"current-tab\", null);\n\n// Local to each context (not synced) - use regular signal\nexport const uiState = signal({\n sidebarOpen: false,\n selectedPanel: \"main\" as \"main\" | \"settings\" | \"debug\",\n});\n",
21
- "/**\n * Context Helpers - DX Improvements for Extension Context Initialization\n *\n * Provides utilities to reduce boilerplate when initializing extension contexts.\n */\n\nimport type { BaseMessage, Context, ExtensionMessage } from \"../types/messages\";\nimport { type MessageBus, getMessageBus } from \"./message-bus\";\n\nexport interface ContextConfig<TMessage extends BaseMessage = ExtensionMessage> {\n /**\n * Called when the context is initialized.\n * Use this to register handlers, setup UI, etc.\n */\n onInit?: (bus: MessageBus<TMessage>) => Promise<void> | void;\n\n /**\n * Called when an error occurs during initialization or runtime.\n */\n onError?: (error: Error, bus: MessageBus<TMessage>) => void;\n\n /**\n * Whether to wait for DOM to be ready before initializing.\n * Only applies to contexts with a window (popup, options, devtools, sidepanel).\n * @default true\n */\n waitForDOM?: boolean;\n\n /**\n * Custom logger prefix.\n * @default `[${context}]`\n */\n logPrefix?: string;\n}\n\n/**\n * Create and initialize an extension context with reduced boilerplate.\n *\n * @example\n * ```typescript\n * // src/popup/index.ts\n * createContext<MyMessages>('popup', {\n * async onInit(bus) {\n * registerHandlers(bus)\n * setupUI()\n * },\n * onError(err) {\n * console.error('Popup failed:', err)\n * }\n * })\n * ```\n */\nexport function createContext<TMessage extends BaseMessage = ExtensionMessage>(\n context: Context,\n config: ContextConfig<TMessage> = {}\n): MessageBus<TMessage> {\n const {\n onInit,\n onError,\n waitForDOM = true,\n logPrefix = `[${context.charAt(0).toUpperCase() + context.slice(1)}]`,\n } = config;\n\n const bus = getMessageBus<TMessage>(context);\n\n // Setup error handler if provided\n if (onError) {\n bus.onError(onError);\n }\n\n const initialize = async () => {\n try {\n if (onInit) {\n await onInit(bus);\n }\n } catch (error) {\n const err = error instanceof Error ? error : new Error(String(error));\n console.error(`${logPrefix} Initialization failed:`, err);\n\n if (onError) {\n onError(err, bus);\n } else {\n throw err;\n }\n }\n };\n\n // Contexts with DOM need to wait for DOMContentLoaded\n const contextsWithDOM: Context[] = [\"popup\", \"options\", \"devtools\", \"sidepanel\", \"content\"];\n\n if (typeof window !== \"undefined\" && contextsWithDOM.includes(context) && waitForDOM) {\n if (document.readyState === \"loading\") {\n document.addEventListener(\"DOMContentLoaded\", () => {\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n });\n } else {\n // DOM already loaded\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n }\n } else {\n // Background, worker, or already initialized\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n }\n\n return bus;\n}\n\n/**\n * Helper to run code only in specific contexts.\n * Useful for shared modules that need context-specific behavior.\n *\n * @example\n * ```typescript\n * // shared/features/analytics.ts\n * const bus = createContext('popup', { ... })\n *\n * if (bus.context === 'popup' || bus.context === 'options') {\n * setupUI()\n * }\n * ```\n *\n * @deprecated Use bus.context directly instead. This function cannot reliably detect context.\n */\nexport function runInContext(\n context: Context,\n contexts: Context | Context[],\n fn: (bus: MessageBus) => void | Promise<void>\n): void {\n const targetContexts = Array.isArray(contexts) ? contexts : [contexts];\n\n if (targetContexts.includes(context)) {\n const bus = getMessageBus(context);\n Promise.resolve(fn(bus)).catch(() => {\n // Error already handled by global error handler\n });\n }\n}\n",
22
- "/**\n * Test Helpers\n *\n * Built-in utilities for testing extensions with the framework.\n * Automatically exposes test results to window for Playwright validation.\n */\n\nimport type { BaseMessage, Context, ExtensionMessage } from \"../types/messages\";\nimport type { MessageBus } from \"./message-bus\";\n\n// Extend Window interface for test results\ndeclare global {\n interface Window {\n __TEST_RESULTS__?: Record<string, unknown>;\n }\n}\n\nexport interface TestCase {\n name: string;\n fn: () => Promise<unknown>;\n result?: unknown;\n error?: string;\n duration?: number;\n}\n\nexport interface TestSuite {\n context: Context;\n tests: Map<string, TestCase>;\n results: {\n passed: number;\n failed: number;\n total: number;\n timestamp: number;\n };\n}\n\nexport class TestRunner<TMessage extends BaseMessage = ExtensionMessage> {\n private suite: TestSuite;\n private bus: MessageBus<TMessage>;\n\n constructor(context: Context, bus: MessageBus<TMessage>) {\n this.bus = bus;\n this.suite = {\n context,\n tests: new Map(),\n results: {\n passed: 0,\n failed: 0,\n total: 0,\n timestamp: Date.now(),\n },\n };\n }\n\n /**\n * Add a test case.\n *\n * @example\n * ```typescript\n * const tests = createTestSuite('popup', bus)\n *\n * tests.add('storage works', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n * ```\n */\n add(name: string, fn: () => Promise<unknown>): this {\n this.suite.tests.set(name, { name, fn });\n return this;\n }\n\n /**\n * Add a test that sends a message and validates the response.\n *\n * @example\n * ```typescript\n * tests.addMessageTest('storage', { type: 'TEST_STORAGE' }, (result) => {\n * return result.success === true\n * })\n * ```\n */\n addMessageTest<T extends TMessage>(\n name: string,\n message: T,\n validator?: (result: unknown) => boolean\n ): this {\n this.add(name, async () => {\n const result = await this.bus.send(message);\n if (validator) {\n return validator(result);\n }\n return result;\n });\n return this;\n }\n\n /**\n * Run all tests and store results.\n *\n * @example\n * ```typescript\n * await tests.run() // Results stored at window.__TEST_RESULTS__.popup\n * ```\n */\n async run(): Promise<TestSuite> {\n this.suite.results = {\n passed: 0,\n failed: 0,\n total: this.suite.tests.size,\n timestamp: Date.now(),\n };\n\n for (const [_name, test] of this.suite.tests) {\n const startTime = Date.now();\n\n try {\n test.result = await test.fn();\n test.duration = Date.now() - startTime;\n this.suite.results.passed++;\n } catch (error) {\n test.error = error instanceof Error ? error.message : String(error);\n test.duration = Date.now() - startTime;\n this.suite.results.failed++;\n }\n }\n\n // Expose results to window for Playwright validation\n this.exposeResults();\n\n return this.suite;\n }\n\n /**\n * Run a single test by name.\n */\n async runTest(name: string): Promise<TestCase> {\n const test = this.suite.tests.get(name);\n if (!test) {\n throw new Error(`Test not found: ${name}`);\n }\n\n const startTime = Date.now();\n\n try {\n test.result = await test.fn();\n test.duration = Date.now() - startTime;\n } catch (error) {\n test.error = error instanceof Error ? error.message : String(error);\n test.duration = Date.now() - startTime;\n }\n\n return test;\n }\n\n /**\n * Get test results.\n */\n getResults(): TestSuite {\n return this.suite;\n }\n\n /**\n * Get a summary of test results.\n */\n getSummary(): {\n context: Context;\n passed: number;\n failed: number;\n total: number;\n duration: number;\n allPassed: boolean;\n } {\n let totalDuration = 0;\n for (const test of this.suite.tests.values()) {\n totalDuration += test.duration || 0;\n }\n\n return {\n context: this.suite.context,\n passed: this.suite.results.passed,\n failed: this.suite.results.failed,\n total: this.suite.results.total,\n duration: totalDuration,\n allPassed: this.suite.results.failed === 0,\n };\n }\n\n /**\n * Expose results to window for Playwright validation.\n * @private\n */\n private exposeResults(): void {\n if (typeof window === \"undefined\") return;\n\n // Create or get the global test results object\n if (!window.__TEST_RESULTS__) {\n window.__TEST_RESULTS__ = {};\n }\n const globalResults = window.__TEST_RESULTS__;\n\n // Convert Map to plain object for serialization\n const testsObject: Record<string, Omit<TestCase, \"fn\">> = {};\n for (const [name, test] of this.suite.tests) {\n testsObject[name] = {\n name: test.name,\n result: test.result,\n ...(test.error !== undefined && { error: test.error }),\n ...(test.duration !== undefined && { duration: test.duration }),\n };\n }\n\n globalResults[this.suite.context] = {\n tests: testsObject,\n results: this.suite.results,\n summary: this.getSummary(),\n };\n }\n\n /**\n * Print test results to console.\n */\n printResults(): void {\n console.group(`[${this.suite.context}] Test Results`);\n\n for (const test of this.suite.tests.values()) {\n if (test.error) {\n console.error(`❌ ${test.name}: ${test.error} (${test.duration}ms)`);\n }\n }\n\n console.groupEnd();\n }\n}\n\n/**\n * Create a test suite for a specific context.\n *\n * @example\n * ```typescript\n * import { createTestSuite } from '@/shared/lib/test-helpers'\n *\n * const tests = createTestSuite('popup', bus)\n *\n * tests.add('storage works', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n *\n * tests.add('tabs query works', async () => {\n * const result = await bus.send({ type: 'TEST_TABS' })\n * return result.tabCount > 0\n * })\n *\n * await tests.run()\n * tests.printResults()\n * ```\n */\nexport function createTestSuite<TMessage extends BaseMessage = ExtensionMessage>(\n context: Context,\n bus: MessageBus<TMessage>\n): TestRunner<TMessage> {\n return new TestRunner<TMessage>(context, bus);\n}\n\n/**\n * Convenience function to run a quick test and log the result.\n *\n * @example\n * ```typescript\n * await quickTest('Storage', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n * ```\n */\nexport async function quickTest(name: string, fn: () => Promise<unknown>): Promise<void> {\n const startTime = Date.now();\n\n try {\n await fn();\n } catch (error) {\n const duration = Date.now() - startTime;\n console.error(\n `❌ ${name}: ${error instanceof Error ? error.message : String(error)} (${duration}ms)`\n );\n }\n}\n"
19
+ "/**\n * Context Helpers - DX Improvements for Extension Context Initialization\n *\n * Provides utilities to reduce boilerplate when initializing extension contexts.\n */\n\nimport type { BaseMessage, Context, ExtensionMessage } from \"../types/messages\";\nimport { getMessageBus, type MessageBus } from \"./message-bus\";\n\nexport interface ContextConfig<TMessage extends BaseMessage = ExtensionMessage> {\n /**\n * Called when the context is initialized.\n * Use this to register handlers, setup UI, etc.\n */\n onInit?: (bus: MessageBus<TMessage>) => Promise<void> | void;\n\n /**\n * Called when an error occurs during initialization or runtime.\n */\n onError?: (error: Error, bus: MessageBus<TMessage>) => void;\n\n /**\n * Whether to wait for DOM to be ready before initializing.\n * Only applies to contexts with a window (popup, options, devtools, sidepanel).\n * @default true\n */\n waitForDOM?: boolean;\n\n /**\n * Custom logger prefix.\n * @default `[${context}]`\n */\n logPrefix?: string;\n}\n\n/**\n * Create and initialize an extension context with reduced boilerplate.\n *\n * @example\n * ```typescript\n * // src/popup/index.ts\n * createContext<MyMessages>('popup', {\n * async onInit(bus) {\n * registerHandlers(bus)\n * setupUI()\n * },\n * onError(err) {\n * console.error('Popup failed:', err)\n * }\n * })\n * ```\n */\nexport function createContext<TMessage extends BaseMessage = ExtensionMessage>(\n context: Context,\n config: ContextConfig<TMessage> = {}\n): MessageBus<TMessage> {\n const {\n onInit,\n onError,\n waitForDOM = true,\n logPrefix = `[${context.charAt(0).toUpperCase() + context.slice(1)}]`,\n } = config;\n\n const bus = getMessageBus<TMessage>(context);\n\n // Setup error handler if provided\n if (onError) {\n bus.onError(onError);\n }\n\n const initialize = async () => {\n try {\n if (onInit) {\n await onInit(bus);\n }\n } catch (error) {\n const err = error instanceof Error ? error : new Error(String(error));\n console.error(`${logPrefix} Initialization failed:`, err);\n\n if (onError) {\n onError(err, bus);\n } else {\n throw err;\n }\n }\n };\n\n // Contexts with DOM need to wait for DOMContentLoaded\n const contextsWithDOM: Context[] = [\"popup\", \"options\", \"devtools\", \"sidepanel\", \"content\"];\n\n if (typeof window !== \"undefined\" && contextsWithDOM.includes(context) && waitForDOM) {\n if (document.readyState === \"loading\") {\n document.addEventListener(\"DOMContentLoaded\", () => {\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n });\n } else {\n // DOM already loaded\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n }\n } else {\n // Background, worker, or already initialized\n initialize().catch((err) => {\n console.error(`${logPrefix} Uncaught initialization error:`, err);\n });\n }\n\n return bus;\n}\n\n/**\n * Helper to run code only in specific contexts.\n * Useful for shared modules that need context-specific behavior.\n *\n * @example\n * ```typescript\n * // shared/features/analytics.ts\n * const bus = createContext('popup', { ... })\n *\n * if (bus.context === 'popup' || bus.context === 'options') {\n * setupUI()\n * }\n * ```\n *\n * @deprecated Use bus.context directly instead. This function cannot reliably detect context.\n */\nexport function runInContext(\n context: Context,\n contexts: Context | Context[],\n fn: (bus: MessageBus) => void | Promise<void>\n): void {\n const targetContexts = Array.isArray(contexts) ? contexts : [contexts];\n\n if (targetContexts.includes(context)) {\n const bus = getMessageBus(context);\n Promise.resolve(fn(bus)).catch(() => {\n // Error already handled by global error handler\n });\n }\n}\n",
20
+ "// State primitives with optional sync and persistence\n\nimport { effect, type Signal, signal } from \"@preact/signals\";\nimport type { Context } from \"../types/messages\";\nimport { getMessageBus, type MessageBus } from \"./message-bus\";\n\ntype StateEntry<T> = {\n signal: Signal<T>;\n clock: number; // Lamport clock for causal ordering\n loaded: Promise<void>;\n updating: boolean;\n};\n\ntype StateOptions<T = unknown> = {\n bus?: MessageBus; // Custom message bus (for testing)\n debounceMs?: number; // Debounce storage writes\n validator?: (value: unknown) => value is T; // Runtime type validation\n};\n\nconst stateRegistry = new Map<string, StateEntry<unknown>>();\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Context detection requires multiple checks\nfunction getCurrentContext(): Context {\n // Detect current context\n if (typeof chrome !== \"undefined\") {\n if (typeof chrome.devtools !== \"undefined\") {\n return \"devtools\";\n }\n if (typeof chrome.runtime !== \"undefined\") {\n try {\n if (typeof self !== \"undefined\" && \"ServiceWorkerGlobalScope\" in self) {\n return \"background\";\n }\n // biome-ignore lint/suspicious/noEmptyBlockStatements: ServiceWorkerGlobalScope check may fail in some contexts\n } catch {}\n }\n }\n\n if (typeof window !== \"undefined\" && typeof document !== \"undefined\") {\n if (typeof chrome === \"undefined\" || typeof chrome.runtime === \"undefined\") {\n return \"page\";\n }\n\n // Distinguish popup/options/offscreen from content scripts by URL\n if (\n typeof window.location !== \"undefined\" &&\n window.location.protocol === \"chrome-extension:\"\n ) {\n const path = window.location.pathname;\n if (path.includes(\"/popup\")) return \"popup\";\n if (path.includes(\"/options\")) return \"options\";\n if (path.includes(\"/offscreen\")) return \"offscreen\";\n // Could also be a custom extension page, default to content\n }\n\n return \"content\";\n }\n\n return \"background\";\n}\n\n/**\n * Shared state: synced across all contexts AND persisted to storage\n *\n * Uses Lamport clock for conflict resolution. State is automatically:\n * - Loaded from chrome.storage on initialization\n * - Synced to other contexts via broadcast messages\n * - Persisted to chrome.storage on every change\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts (use content script state instead)\n *\n * @param key - Unique identifier for this state (e.g., \"app-settings\")\n * @param initialValue - Default value if nothing is in storage\n * @param options - Optional configuration (bus, debounceMs)\n * @returns Reactive signal that stays in sync across all contexts\n *\n * @example\n * ```typescript\n * // Define once, use everywhere\n * const settings = $sharedState(\"settings\", { theme: \"dark\" })\n *\n * // Changes automatically sync\n * settings.value = { theme: \"light\" }\n * ```\n */\nexport function $sharedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: true,\n persist: true,\n });\n}\n\n/**\n * Synced state: synced across all contexts but NOT persisted\n *\n * State is broadcast to all contexts in real-time but resets on extension reload.\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts\n *\n * @param key - Unique identifier for this state\n * @param initialValue - Default value\n * @param options - Optional configuration\n * @returns Reactive signal synced across contexts (but not persisted)\n *\n * @example\n * ```typescript\n * // Temporary shared state\n * const activeTabId = $syncedState(\"active-tab\", null)\n * ```\n */\nexport function $syncedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: true,\n persist: false,\n });\n}\n\n/**\n * Persisted state: persisted to storage but NOT synced across contexts\n *\n * Each context has its own copy of the state, persisted independently.\n *\n * Available in: background, popup, options, devtools, content scripts\n * ⚠️ NOT available in page scripts\n *\n * @param key - Unique identifier (use prefix like \"popup:state\" to avoid collisions)\n * @param initialValue - Default value\n * @param options - Optional configuration\n * @returns Reactive signal persisted to storage (but not synced)\n *\n * @example\n * ```typescript\n * // Each context has its own persisted state\n * const popupState = $persistedState(\"popup:last-panel\", \"home\")\n * const devtoolsState = $persistedState(\"devtools:expanded\", true)\n * ```\n */\nexport function $persistedState<T>(\n key: string,\n initialValue: T,\n options: StateOptions<T> = {}\n): Signal<T> {\n return createState(key, initialValue, {\n ...options,\n sync: false,\n persist: true,\n });\n}\n\n/**\n * Local state: not synced, not persisted (like regular Preact signal)\n *\n * Simple reactive state that lives only in the current context.\n * Resets on reload or context restart.\n *\n * Available in: all contexts (including page scripts)\n *\n * @param initialValue - Default value\n * @returns Reactive signal (local only)\n *\n * @example\n * ```typescript\n * // Local UI state\n * const isLoading = $state(false)\n * const error = $state<string | null>(null)\n * ```\n */\nexport function $state<T>(initialValue: T): Signal<T> {\n return signal(initialValue);\n}\n\ntype InternalStateOptions<T = unknown> = StateOptions<T> & {\n sync: boolean;\n persist: boolean;\n};\n\n// Deep equality check to prevent redundant updates\nfunction deepEqual(a: unknown, b: unknown): boolean {\n if (a === b) return true;\n if (a == null || b == null) return false;\n if (typeof a !== \"object\" || typeof b !== \"object\") return false;\n\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n\n if (keysA.length !== keysB.length) return false;\n\n for (const key of keysA) {\n if (!keysB.includes(key)) return false;\n if (!deepEqual((a as Record<string, unknown>)[key], (b as Record<string, unknown>)[key]))\n return false;\n }\n\n return true;\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Core state management logic requires coordination of multiple concerns\nfunction createState<T>(key: string, initialValue: T, options: InternalStateOptions<T>): Signal<T> {\n // Return existing signal if already registered\n if (stateRegistry.has(key)) {\n return stateRegistry.get(key)?.signal as Signal<T>;\n }\n\n const currentContext = getCurrentContext();\n\n // Page scripts should not have stateful operations\n // They are execution contexts for content scripts, not independent contexts\n if (currentContext === \"page\" && (options.sync || options.persist)) {\n const stateFn =\n options.sync && options.persist\n ? \"$sharedState\"\n : options.persist\n ? \"$persistedState\"\n : \"$syncedState\";\n\n throw new Error(\n `[web-ext] ${stateFn}() is not available in page context.\\nPage scripts are execution contexts for content scripts and should not maintain state.\\nUse state in the content script instead, or use $state() for local-only state.`\n );\n }\n\n const sig = signal(initialValue);\n\n const entry: StateEntry<T> = {\n signal: sig,\n clock: 0,\n loaded: Promise.resolve(),\n updating: false,\n };\n\n // Lazy bus initialization\n let bus: MessageBus | null = null;\n const getBus = () => {\n if (!bus && typeof chrome !== \"undefined\") {\n bus = options.bus || getMessageBus(currentContext);\n }\n return bus;\n };\n\n // Load from storage if persist is enabled\n if (options.persist) {\n entry.loaded = loadFromStorage(key, sig, entry, getBus(), options.validator);\n }\n\n // Watch for changes after initial load\n entry.loaded.then(() => {\n let debounceTimer: NodeJS.Timeout | null = null;\n let previousValue = sig.value;\n let isFirstRun = true;\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: Sync effect requires coordination of multiple state change scenarios\n effect(() => {\n // Skip if update in progress (from incoming message)\n if (entry.updating) return;\n\n const value = sig.value;\n\n // Skip first run (effect fires immediately on registration)\n if (isFirstRun) {\n isFirstRun = false;\n return;\n }\n\n // Skip if value hasn't changed (deep equality check)\n if (deepEqual(value, previousValue)) {\n return;\n }\n\n previousValue = value;\n\n // Increment clock monotonically\n entry.clock++;\n\n const doUpdate = () => {\n // Persist to storage\n if (options.persist) {\n persistToStorage(key, value, entry.clock, getBus());\n }\n\n // Broadcast to other contexts\n if (options.sync) {\n broadcastUpdate(key, value, entry.clock, getBus());\n }\n };\n\n // Debounce if specified\n if (options.debounceMs) {\n if (debounceTimer) clearTimeout(debounceTimer);\n debounceTimer = setTimeout(doUpdate, options.debounceMs);\n } else {\n doUpdate();\n }\n });\n });\n\n // Listen for updates from other contexts (only if sync enabled)\n if (options.sync) {\n const messageBus = getBus();\n if (messageBus) {\n // Auto-connect for contexts that need it (popup, options, devtools)\n // Safe to call multiple times because:\n // - getMessageBus() returns a singleton per context\n // - connect() is idempotent (checks if port exists and returns early)\n // Background doesn't need to connect (it's the hub)\n // Content scripts connect explicitly when needed\n if (\n currentContext === \"popup\" ||\n currentContext === \"options\" ||\n currentContext === \"devtools\"\n ) {\n messageBus.connect(currentContext);\n }\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: State sync requires validation and conflict resolution\n messageBus.on(\"STATE_SYNC\", async (payload) => {\n if (payload.key !== key) return undefined;\n\n const oldClock = entry.clock;\n\n // Lamport clock rule: Always update to max(local, received)\n // This maintains causal ordering even when rejecting updates\n entry.clock = Math.max(entry.clock, payload.clock);\n\n // Only accept value updates if received clock is strictly greater than old local clock\n // This ensures we only apply causally newer updates\n if (payload.clock > oldClock) {\n // Validate incoming value if validator provided\n if (options.validator && !options.validator(payload.value)) {\n console.warn(\n `[web-ext] State \"${key}\": Received invalid value from sync (clock: ${payload.clock})`,\n payload.value\n );\n return undefined;\n }\n\n // Skip redundant updates (deep equality check)\n if (deepEqual(entry.signal.value, payload.value)) {\n return undefined;\n }\n\n applyUpdate(entry, payload.value as T, payload.clock);\n }\n\n return undefined;\n });\n }\n }\n\n stateRegistry.set(key, entry as StateEntry<unknown>);\n return sig;\n}\n\nasync function loadFromStorage<T>(\n key: string,\n sig: Signal<T>,\n entry: StateEntry<T>,\n bus: MessageBus | null,\n validator?: (value: unknown) => value is T\n): Promise<void> {\n if (!bus) return;\n\n try {\n const result = await bus.adapters.storage.get([key, `${key}:clock`]);\n\n if (result[key] !== undefined) {\n const storedValue = result[key];\n\n // Validate stored value if validator provided\n if (validator) {\n if (validator(storedValue)) {\n sig.value = storedValue;\n } else {\n console.warn(\n `[web-ext] State \"${key}\": Stored value failed validation, using initial value`,\n storedValue\n );\n }\n } else {\n sig.value = storedValue as T;\n }\n }\n\n if (result[`${key}:clock`] !== undefined) {\n entry.clock = result[`${key}:clock`] as number;\n }\n } catch (error) {\n console.warn(`[web-ext] Failed to load state from storage: ${key}`, error);\n }\n}\n\nfunction persistToStorage<T>(key: string, value: T, clock: number, bus: MessageBus | null): void {\n if (!bus) return;\n\n try {\n bus.adapters.storage.set({\n [key]: value,\n [`${key}:clock`]: clock,\n });\n } catch (error) {\n console.warn(`Failed to persist state to storage: ${key}`, error);\n }\n}\n\nfunction broadcastUpdate<T>(key: string, value: T, clock: number, bus: MessageBus | null): void {\n if (!bus) return;\n\n try {\n bus.broadcast({\n type: \"STATE_SYNC\",\n key,\n value,\n clock,\n });\n } catch (error) {\n console.warn(`Failed to broadcast state update: ${key}`, error);\n }\n}\n\nfunction applyUpdate<T>(entry: StateEntry<T>, value: T, clock: number): void {\n entry.updating = true;\n entry.signal.value = value;\n entry.clock = clock;\n entry.updating = false;\n}\n\n/**\n * Get state by key (useful for retrieving state without re-creating)\n */\nexport function getStateByKey<T>(key: string): Signal<T> | undefined {\n const entry = stateRegistry.get(key);\n return entry?.signal as Signal<T> | undefined;\n}\n\n/**\n * Clear state registry (useful for testing)\n */\nexport function clearStateRegistry(): void {\n stateRegistry.clear();\n}\n",
21
+ "/**\n * Test Helpers\n *\n * Built-in utilities for testing extensions with the framework.\n * Automatically exposes test results to window for Playwright validation.\n */\n\nimport type { BaseMessage, Context, ExtensionMessage } from \"../types/messages\";\nimport type { MessageBus } from \"./message-bus\";\n\n// Extend Window interface for test results\ndeclare global {\n interface Window {\n __TEST_RESULTS__?: Record<string, unknown>;\n }\n}\n\nexport interface TestCase {\n name: string;\n fn: () => Promise<unknown>;\n result?: unknown;\n error?: string;\n duration?: number;\n}\n\nexport interface TestSuite {\n context: Context;\n tests: Map<string, TestCase>;\n results: {\n passed: number;\n failed: number;\n total: number;\n timestamp: number;\n };\n}\n\nexport class TestRunner<TMessage extends BaseMessage = ExtensionMessage> {\n private suite: TestSuite;\n private bus: MessageBus<TMessage>;\n\n constructor(context: Context, bus: MessageBus<TMessage>) {\n this.bus = bus;\n this.suite = {\n context,\n tests: new Map(),\n results: {\n passed: 0,\n failed: 0,\n total: 0,\n timestamp: Date.now(),\n },\n };\n }\n\n /**\n * Add a test case.\n *\n * @example\n * ```typescript\n * const tests = createTestSuite('popup', bus)\n *\n * tests.add('storage works', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n * ```\n */\n add(name: string, fn: () => Promise<unknown>): this {\n this.suite.tests.set(name, { name, fn });\n return this;\n }\n\n /**\n * Add a test that sends a message and validates the response.\n *\n * @example\n * ```typescript\n * tests.addMessageTest('storage', { type: 'TEST_STORAGE' }, (result) => {\n * return result.success === true\n * })\n * ```\n */\n addMessageTest<T extends TMessage>(\n name: string,\n message: T,\n validator?: (result: unknown) => boolean\n ): this {\n this.add(name, async () => {\n const result = await this.bus.send(message);\n if (validator) {\n return validator(result);\n }\n return result;\n });\n return this;\n }\n\n /**\n * Run all tests and store results.\n *\n * @example\n * ```typescript\n * await tests.run() // Results stored at window.__TEST_RESULTS__.popup\n * ```\n */\n async run(): Promise<TestSuite> {\n this.suite.results = {\n passed: 0,\n failed: 0,\n total: this.suite.tests.size,\n timestamp: Date.now(),\n };\n\n for (const [_name, test] of this.suite.tests) {\n const startTime = Date.now();\n\n try {\n test.result = await test.fn();\n test.duration = Date.now() - startTime;\n this.suite.results.passed++;\n } catch (error) {\n test.error = error instanceof Error ? error.message : String(error);\n test.duration = Date.now() - startTime;\n this.suite.results.failed++;\n }\n }\n\n // Expose results to window for Playwright validation\n this.exposeResults();\n\n return this.suite;\n }\n\n /**\n * Run a single test by name.\n */\n async runTest(name: string): Promise<TestCase> {\n const test = this.suite.tests.get(name);\n if (!test) {\n throw new Error(`Test not found: ${name}`);\n }\n\n const startTime = Date.now();\n\n try {\n test.result = await test.fn();\n test.duration = Date.now() - startTime;\n } catch (error) {\n test.error = error instanceof Error ? error.message : String(error);\n test.duration = Date.now() - startTime;\n }\n\n return test;\n }\n\n /**\n * Get test results.\n */\n getResults(): TestSuite {\n return this.suite;\n }\n\n /**\n * Get a summary of test results.\n */\n getSummary(): {\n context: Context;\n passed: number;\n failed: number;\n total: number;\n duration: number;\n allPassed: boolean;\n } {\n let totalDuration = 0;\n for (const test of this.suite.tests.values()) {\n totalDuration += test.duration || 0;\n }\n\n return {\n context: this.suite.context,\n passed: this.suite.results.passed,\n failed: this.suite.results.failed,\n total: this.suite.results.total,\n duration: totalDuration,\n allPassed: this.suite.results.failed === 0,\n };\n }\n\n /**\n * Expose results to window for Playwright validation.\n * @private\n */\n private exposeResults(): void {\n if (typeof window === \"undefined\") return;\n\n // Create or get the global test results object\n if (!window.__TEST_RESULTS__) {\n window.__TEST_RESULTS__ = {};\n }\n const globalResults = window.__TEST_RESULTS__;\n\n // Convert Map to plain object for serialization\n const testsObject: Record<string, Omit<TestCase, \"fn\">> = {};\n for (const [name, test] of this.suite.tests) {\n testsObject[name] = {\n name: test.name,\n result: test.result,\n ...(test.error !== undefined && { error: test.error }),\n ...(test.duration !== undefined && { duration: test.duration }),\n };\n }\n\n globalResults[this.suite.context] = {\n tests: testsObject,\n results: this.suite.results,\n summary: this.getSummary(),\n };\n }\n\n /**\n * Print test results to console.\n */\n printResults(): void {\n console.group(`[${this.suite.context}] Test Results`);\n\n for (const test of this.suite.tests.values()) {\n if (test.error) {\n console.error(`❌ ${test.name}: ${test.error} (${test.duration}ms)`);\n }\n }\n\n console.groupEnd();\n }\n}\n\n/**\n * Create a test suite for a specific context.\n *\n * @example\n * ```typescript\n * import { createTestSuite } from '@/shared/lib/test-helpers'\n *\n * const tests = createTestSuite('popup', bus)\n *\n * tests.add('storage works', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n *\n * tests.add('tabs query works', async () => {\n * const result = await bus.send({ type: 'TEST_TABS' })\n * return result.tabCount > 0\n * })\n *\n * await tests.run()\n * tests.printResults()\n * ```\n */\nexport function createTestSuite<TMessage extends BaseMessage = ExtensionMessage>(\n context: Context,\n bus: MessageBus<TMessage>\n): TestRunner<TMessage> {\n return new TestRunner<TMessage>(context, bus);\n}\n\n/**\n * Convenience function to run a quick test and log the result.\n *\n * @example\n * ```typescript\n * await quickTest('Storage', async () => {\n * const result = await bus.send({ type: 'TEST_STORAGE' })\n * return result.success\n * })\n * ```\n */\nexport async function quickTest(name: string, fn: () => Promise<unknown>): Promise<void> {\n const startTime = Date.now();\n\n try {\n await fn();\n } catch (error) {\n const duration = Date.now() - startTime;\n console.error(\n `❌ ${name}: ${error instanceof Error ? error.message : String(error)} (${duration}ms)`\n );\n }\n}\n",
22
+ "// Shared application state\n\nimport { signal } from \"@preact/signals\";\nimport { $sharedState, $syncedState } from \"../lib/state\";\nimport type { Settings } from \"../types/messages\";\nimport { defaultSettings as _defaultSettings } from \"../types/messages\";\n\n// Re-export for convenience\nexport { defaultSettings } from \"../types/messages\";\n\n// Synced across all contexts, persisted to storage\nexport const settings = $sharedState<Settings>(\"app-settings\", _defaultSettings);\n\n// Synced but not persisted\nexport const currentTab = $syncedState<number | null>(\"current-tab\", null);\n\n// Local to each context (not synced) - use regular signal\nexport const uiState = signal({\n sidebarOpen: false,\n selectedPanel: \"main\" as \"main\" | \"settings\" | \"debug\",\n});\n"
23
23
  ],
24
- "mappings": "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",
25
- "debugId": "6EB80BA3B2CEBE8A64756E2164756E21",
24
+ "mappings": "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",
25
+ "debugId": "099A20C25FF495A164756E2164756E21",
26
26
  "names": []
27
27
  }
@@ -1,7 +1,7 @@
1
1
  import type { ContextMenusAdapter } from "../context-menus.adapter";
2
2
  export declare class ChromeContextMenusAdapter implements ContextMenusAdapter {
3
3
  create(createProperties: chrome.contextMenus.CreateProperties): Promise<void>;
4
- update(id: string, updateProperties: chrome.contextMenus.UpdateProperties): Promise<void>;
4
+ update(id: string, updateProperties: Omit<chrome.contextMenus.CreateProperties, "id">): Promise<void>;
5
5
  remove(id: string): Promise<void>;
6
6
  removeAll(): Promise<void>;
7
7
  onClicked(callback: (info: chrome.contextMenus.OnClickData, tab?: chrome.tabs.Tab) => void): void;
@@ -6,8 +6,8 @@ export declare class ChromeTabsAdapter implements TabsAdapter {
6
6
  reload(tabId: number, reloadProperties?: {
7
7
  bypassCache?: boolean;
8
8
  }): Promise<void>;
9
- onRemoved(callback: (tabId: number, removeInfo: chrome.tabs.TabRemoveInfo) => void): void;
10
- onUpdated(callback: (tabId: number, changeInfo: chrome.tabs.TabChangeInfo, tab: chrome.tabs.Tab) => void): void;
9
+ onRemoved(callback: (tabId: number, removeInfo: chrome.tabs.OnRemovedInfo) => void): void;
10
+ onUpdated(callback: (tabId: number, changeInfo: chrome.tabs.OnUpdatedInfo, tab: chrome.tabs.Tab) => void): void;
11
11
  onActivated(callback: (activeInfo: {
12
12
  tabId: number;
13
13
  windowId: number;
@@ -6,7 +6,7 @@ export interface ContextMenusAdapter {
6
6
  /**
7
7
  * Update context menu item
8
8
  */
9
- update(id: string, updateProperties: chrome.contextMenus.UpdateProperties): Promise<void>;
9
+ update(id: string, updateProperties: Omit<chrome.contextMenus.CreateProperties, "id">): Promise<void>;
10
10
  /**
11
11
  * Remove context menu item
12
12
  */