Skip to content

mubaidr/vite-vue3-browser-extension-v3

Folders and files

NameName
Last commit message
Last commit date

Latest commit

f47629c Β· Jan 9, 2025
Dec 25, 2024
Dec 25, 2024
Dec 25, 2024
Dec 26, 2024
Dec 25, 2024
Jan 9, 2025
Dec 26, 2024
Feb 26, 2023
Mar 10, 2023
Aug 27, 2023
Dec 25, 2024
Dec 25, 2024
Jan 9, 2025
Dec 26, 2024
Dec 25, 2024
Dec 25, 2024
Dec 25, 2024
Dec 25, 2024
Jan 9, 2025
Jan 8, 2025
Feb 26, 2023
Dec 25, 2024
Dec 25, 2024
Dec 25, 2024
Dec 28, 2024
Dec 28, 2024
Jan 9, 2025

Repository files navigation

vite-vue3-browser-extension-v3

build

A Vite powered WebExtension (Chrome, FireFox, etc.) starter template based on manifest 3, vue3 and vite and alot more preconfigured.

Screenshots

Options Options Options (Dark Mode)

Update Screen Update Screen

Features

  • 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.

Directory Structure

.
β”œβ”€β”€ 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

Development tools

Vite Plugins

Vue Plugins

  • 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

Plugins

  • Marked - A markdown parser and compiler. Used for CHANGELOG.md to show in Update page

UI Frameworks

  • 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.

WebExtension Libraries

Coding Style

Use the Template

GitHub Template

Create a repo from this template on GitHub.

Clone to local

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

Browser Related Configurations

  • manifest.config.ts - Base extension manifest with common configuration
  • manifest.chrome.config.ts - Chrome/ chromium based browsers specific manifest
  • manifest.firefox.config.ts - Firefox spefic manifest
  • vite.config.ts - Base vite configuration
  • vite.chrome.config.ts - Chrome/ chromium based browsers specific vite configuration
  • vite.firefox.config.ts - Firefox specific vite configuration

Scripts

  • pnpm dev - Start development server
  • pnpm build - Build extension
  • pnpm 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.

Support

If you like this project, you can support me by donating mubaidr and starring ⭐ this repository.

Hire me

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.

Contributors

mubaidr
Muhammad Ubaid Raza
Dreamlinerm
Dreamliner
baramofme
Jihoon Yi
poncianodiego
Diego Ponciano
IgorFZ
igorfz
hi2code
hi2code
justorez
Null