A Vite powered WebExtension (Chrome, FireFox, etc.) starter template based on manifest 3
, vue3
and vite
and alot more preconfigured.
- Boiler plate Pages for
- Background
- Action Popup
- Options
- Content Script
- Devtools panel
- Browser Side Panel
- Setup pages for Install and Update events
- Offscreen pages for audio, screen recording etc
- Sample pages for Contact, About, Pricing etc
- Dynamic/ Directory based routing. Just add a file in
src/pages
or relevant ui directory and it will be automatically registered as a route - State & UI Components
- Header
- Footer
- Locale Switch (i18n)
- Theme Switch (dark/light)
- Loading Spinner
- Error Boundary
- Empty State
- Notifications using
notivue
- Store for options preconfigured etc
- Composables for
- i18n
- Theme
- Notifications
- Loading
- Error handling
useBrowserStorage
for extension settings and user options management
- Preconfigured Pinia Store (optional perisitent and non-persistent)
- System wide
- Easily extendable
- Type safe
Please create an issue if you feel some feature is missing or could be improved.
.
├── dist # Built extension files
│ ├── chrome # Chrome-specific build
│ └── firefox # Firefox-specific build
├── public # Static assets
│ └── icons # Extension icons
├── scripts # Build/dev scripts
├── src # Source code
│ ├── assets # Global assets (images, styles)
│ ├── background # Extension background script
│ ├── components # Shared Vue components. Some prebuilt components are available like `Header`, `Footer`, `LocaleSwitch`, `ThemeSwitch`, `LoadingSpinner`, `ErrorBoundary`, `EmptyState` etc
│ ├── composables # Vue composables/hooks
│ │ ├── useBrowserStorage # Browser storage for both `sync` and `local`
│ │ ├── useLocale # Manage locale in your extension
│ │ ├── useTheme # Manage theme in your extension
│ ├── content-script # Content scripts injected into pages
│ ├── devtools # Chrome devtools panel
│ ├── locales # i18n translation files
│ ├── offscreen # Offscreen pages (audio, recording)
│ ├── stores # Pinia stores
│ ├── types # TypeScript type definitions
│ ├── ui # UI pages
│ │ ├── action-popup # Browser toolbar popup
│ │ ├── common # Shared pages
│ │ ├── content-script-iframe # Content script app injected into pages by content script
│ │ ├── devtools-panel # Devtools panel UI
│ │ ├── options-page # Extension options
│ │ ├── setup # Install/update pages
│ │ └── side-panel # Browser side panel
│ └── utils # Shared utilities
├── manifest.config.ts # Base manifest configuration
├── vite.chrome.config.ts # Chrome specific Vite configuration overrides
├── vite.config.ts # Base Vite configuration
├── vite.firefox.config.ts # Firefox specific Vite configuration overrides
├── tailwind.config.cjs # Tailwind CSS configuration
└── package.json # Project dependencies and scripts
unplugin-vue-router
- File system based route generator for Viteunplugin-auto-import
- Directly usebrowser
and Vue Composition API without importingunplugin-vue-components
- components auto importunplugin-icons
- icons as componentsunplugin-turbo-console
- Improve the Developer Experience of console@intlify/unplugin-vue-i18n
- unplugin for Vue I18n
- Pinia - Intuitive, type safe, light and flexible Store for Vue
- VueUse - collection of useful composition APIs
- Notivue - Powerful toast notification system for Vue and Nuxt.
- Vue-i18n - Internationalization plugin for Vue.js
- Marked - A markdown parser and compiler. Used for CHANGELOG.md to show in Update page
- tailwindcss - A utility-first CSS framework
- daisyUI - The most popular component library for Tailwind CSS
Tailwind css forms
and typography
plugins are enabled for default styling of form controls.
webext-bridge
- effortlessly communication between contextswebextension-polyfill
- A lightweight polyfill library for Promise-based WebExtension APIs in Chrome
- TypeScript - Typed JavaScript at Any Scale
- ESLint - Linting utility for JavaScript and JSX
- Prettier - Code formatter
- Use Composition API with
<script setup>
SFC syntax - Use Composition API with
setup
SFC syntax in Pinia stores
Create a repo from this template on GitHub.
If you prefer to do it manually with the cleaner git history
If you don't have pnpm installed, run: npm install -g pnpm
pnpx degit mubaidr/vite-vue3-browser-extension-v3 my-webext
cd my-webext
pnpm i
manifest.config.ts
- Base extension manifest with common configurationmanifest.chrome.config.ts
- Chrome/ chromium based browsers specific manifestmanifest.firefox.config.ts
- Firefox spefic manifestvite.config.ts
- Base vite configurationvite.chrome.config.ts
- Chrome/ chromium based browsers specific vite configurationvite.firefox.config.ts
- Firefox specific vite configuration
pnpm dev
- Start development serverpnpm build
- Build extensionpnpm lint
- Lint files
You can also use pnpm dev:chrome, pnpm dev:firefox, pnpm build:chrome, pnpm build:firefox, pnpm lint:fix
Then load extension in browser with the dist/
folder
Note: Pack files under dist/chrome
or dist/firefox
, you can upload to appropriate extension store.
If you like this project, you can support me by donating mubaidr and starring ⭐ this repository.
I am a full stack developer. I am open to work. If you are looking for a developer or have a project you want to start, please visit my profile and website here: mubaidr.
Muhammad Ubaid Raza |
Dreamliner |
Jihoon Yi |
Diego Ponciano |
igorfz |
hi2code |
Null |