Claude-skill-registry browser-extension
Master specialized skill for building 2025/2026-grade browser extensions. Deep expertise in Manifest v3, Service Worker persistence (Alarms, Offscreen API), Side Panel API, and Cross-Browser compatibility.
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/browser-extension" ~/.claude/skills/majiayu000-claude-skill-registry-browser-extension && rm -rf "$T"
manifest:
skills/data/browser-extension/SKILL.mdsource content
<domain_overview>
🌐 BROWSER EXTENSION: THE 2026 MASTERCLASS
Philosophy: Extensions are ephemeral, restricted, yet powerful. Persistence is an Art. Security is a Mandate. Design Constraint: For UI/UX, Aesthetics, and Layout, YOU MUST REFER TO THE
SKILL. PERSISTENCE PARADOX GUARD (CRITICAL): Never rely on global variables or in-memory state in background scripts. AI-generated code frequently fails by assuming Manifest V3 service workers are persistent. They are NOT; they terminate after 30 seconds of inactivity. You MUST backup every piece of state tofrontend-designorchrome.storageimmediately upon change. This skill aims to eliminate "volatile-state" bugs typical of generic AI implementations. If data is not in durable storage, it does not exist. </domain_overview> <manifest_architecture>IndexedDB
🏗️ PROTOCOL 1: THE MANIFEST V3 CONSTITUTION
All extensions must be built on Manifest v3. No exceptions.
- Manifest Blueprint:
- Service Workers: No persistent background pages. Use
."background": { "service_worker": "background.js" } - No Remote Code: All scripts must be local.
is forbidden.unsafe-eval - Permissions: Principle of Least Privilege. Use
where possible.optional_permissions - Action UI: Prefer
overaction
orbrowser_action
.page_action
- Service Workers: No persistent background pages. Use
- Side Panel Supremacy:
- Requirement: Use
for persistent, non-intrusive experiences.chrome.sidePanel - API:
. </manifest_architecture> <persistence_engine>chrome.sidePanel.setOptions({ path: 'sidepanel.html', enabled: true })
- Requirement: Use
⚡ PROTOCOL 2: THE PERSISTENCE ENGINE (ANTI-TERMINATION)
Service Workers sleep. You must keep the logic alive.
- The Alarm Pulse:
- Use
to wake up the Service Worker every 1-5 minutes for background sync.chrome.alarms
- Use
- The Offscreen Document (When needed):
- Use the
API for tasks like DOM parsing, heavy calculations, or keeping the SW alive via periodic messaging.offscreen
- Use the
- State Management Protocol:
- NEVER rely on global variables.
- Mandatory: Use
for transient session-only secrets.chrome.storage.session - Mandatory: Use
orIndexedDB
for large datasets and persistent user data. </persistence_engine> <security_fortress>chrome.storage.local
🔐 PROTOCOL 3: THE SECURITY FORTRESS
- Context Bridge Safety:
- Content Scripts are "Hostile Territory". Always sanitize data passed to the Service Worker via
.chrome.runtime.sendMessage
- Content Scripts are "Hostile Territory". Always sanitize data passed to the Service Worker via
- Declarative Net Request:
- Use
for blocking/modifying headers. Only usedeclarativeNetRequest
as a fallback for Firefox if dynamic rules are critical. </security_fortress> <design_integration>webRequest
- Use
🎨 PROTOCOL 4: DESIGN & UI/UX (INTEGRATED)
Direct Instruction: You are an extension developer, not a designer. You must outsource the "Soul" of the UI.
- UI Execution:
- Popup/SidePanel: Follow the 8-Point Grid and Glassmorphism rules from
.frontend-design - Component Atomization: Use Atomic Design 2.0 principles.
- Friction: Ensure the popup interaction is < 400ms (Doherty Threshold). </design_integration> <audit_and_reference>
- Popup/SidePanel: Follow the 8-Point Grid and Glassmorphism rules from
🛠️ PROTOCOL 5: SCRIPT ENFORCEMENT (THE SENTINEL)
Every extension build MUST pass the high-tier audit suite.
- manifest-auditor.js:
- Rule: MV3 compliance and CSP safety. No broad permissions.
- persistence-check.js:
- Rule: Service Worker "Heartbeat" verification and State integrity.
- asset-master.js:
- Rule: Icon dimensional audit and asset optimization.
📂 COGNITIVE AUDIT CYCLE
- Run
-> Clean?node scripts/js/manifest-auditor.js - Run
-> Heartbeat detected?node scripts/js/persistence-check.js - Run
-> Assets optimized?node scripts/js/asset-master.js - MANDATORY: Run
-> All paths pass?playwright test - Is it Manifest v3 compliant?
- Does the Service Worker handle termination gracefully (State stored)?
- Are permissions minimized?
- Is the UI justified by a "Narrative-First" screenplay from
?frontend-design
Link: frontend-design </audit_and_reference>