emuniq/filament-qr-scanner 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

emuniq/filament-qr-scanner

Composer 安装命令:

composer require emuniq/filament-qr-scanner

包简介

A Filament v3 & v4 plugin for HTML5 QR/barcode camera scanning with multi-camera support, permission handling, and Livewire integration.

README 文档

README

A Filament v3 & v4 plugin for HTML5 QR/barcode camera scanning. Opens a Filament modal with live camera feed, supports multi-camera switching, handles permissions gracefully, and integrates directly with Livewire.

Features

  • Zero configuration - works out of the box
  • Multi-camera support - switch between front/back cameras
  • Permission handling - friendly help messages when camera is denied
  • Livewire integration - scanned value sent directly to your component
  • Filament native - uses Filament modals, buttons, and styling
  • Dark mode support
  • Localized - English and Spanish included, easily extendable
  • Mobile ready - iOS Safari, Android Chrome, desktop browsers
  • Camera persistence - remembers last selected camera via localStorage

Requirements

  • PHP 8.1+
  • Laravel 10.0+
  • Filament 3.0+ or 4.0+

Installation

composer require emuniq/filament-qr-scanner

That's it! The plugin auto-registers to all Filament panels.

Usage

Basic

Add the component to any Livewire/Filament page:

<x-qr-camera-scanner />

Then in your Livewire component:

public string $scanInput = '';

public function processScan(): void
{
    $qr = trim($this->scanInput);
    $this->scanInput = '';

    // Do something with $qr...
}

Custom Props

<x-qr-camera-scanner
    wire-model="myProperty"
    wire-action="myMethod"
    button-label="Scan Product"
    button-color="success"
    button-size="md"
    modal-heading="Scan Product QR"
    :fps="15"
    :qrbox-size="300"
/>

Available Props

Prop Default Description
wire-model scanInput Livewire property to receive scanned value
wire-action processScan Livewire method called after scan
button-label Scan QR Button text (auto-translated)
button-color primary Filament button color
button-size lg Filament button size
modal-heading Scan QR Code Modal title (auto-translated)
fps 10 Scanner frames per second
qrbox-size 250 QR scanning area in pixels

Translations

English and Spanish are included. To add your own:

php artisan vendor:publish --tag=filament-qr-scanner-translations

Then edit lang/vendor/filament-qr-scanner/{locale}/scanner.php.

How It Works

  1. User clicks the camera button
  2. Requests camera permission (with fallback constraints)
  3. Opens a Filament modal with live camera feed
  4. On successful scan, sets the Livewire property and calls the action
  5. Automatically stops camera and closes modal

Uses html5-qrcode v2.3.8 loaded on demand via x-load-js.

Browser Support

  • Chrome/Chromium (Desktop & Android)
  • Safari (iOS & macOS)
  • Firefox
  • Edge

License

MIT

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Blade

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-30

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固