@ -133,289 +133,61 @@ export class CapacitorQRScanner implements QRScannerService { 
			
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  // Implement other interface methods...  async requestPermissions() { 
			
				
				
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					5. **Implement Web Scanner** 
			
		
	
		
		
			
				
					```typescript 
			
		
	
		
		
			
				
					// WebDialogQRScanner.ts 
			
		
	
		
		
			
				
					export class WebDialogQRScanner implements QRScannerService { 
			
		
	
		
		
			
				
					  private dialogInstance: App | null = null; 
			
		
	
		
		
			
				
					  private dialogComponent: InstanceType<typeof QRScannerDialog> | null = null; 
			
		
	
		
		
			
				
					  private scanListener: ScanListener | null = null; 
			
		
	
		
		
			
				
					  async checkPermissions(): Promise<boolean> { 
			
		
	
		
		
	
		
		
			
				
					    try {    try { 
			
		
	
		
		
			
				
					
					      const permissions = await navigator.permissions.query({      const { camera } = await BarcodeScanner.requestPermissions(); 
			
				
				
			
		
	
		
		
			
				
					
					        name: 'camera' as PermissionName      return camera === 'granted'; 
			
				
				
			
		
	
		
		
			
				
					      }); 
			
		
	
		
		
			
				
					      return permissions.state === 'granted'; 
			
		
	
		
		
	
		
		
	
		
		
			
				
					    } catch (error) {    } catch (error) { 
			
		
	
		
		
			
				
					
					      logger.error('Error check ing camera permissions:', error);      logger.error('Error requesting camera permissions:', error); 
			
				
				
			
		
	
		
		
	
		
		
			
				
					      return false;      return false; 
			
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  // Implement other interface methods...  async isSupported() { 
			
				
				
			
		
	
		
		
			
				
					
					}    return Capacitor.isNativePlatform(); 
			
				
				
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					6. **Create Dialog Component** 
			
		
	
		
		
			
				
					```vue 
			
		
	
		
		
			
				
					<!-- QRScannerDialog.vue --> 
			
		
	
		
		
			
				
					<template> 
			
		
	
		
		
			
				
					  <div v-if="visible" class="dialog-overlay z-[60]"> 
			
		
	
		
		
			
				
					    <div class="dialog relative"> 
			
		
	
		
		
			
				
					      <!-- Dialog content --> 
			
		
	
		
		
			
				
					      <div v-if="useQRReader"> 
			
		
	
		
		
			
				
					        <qrcode-stream 
			
		
	
		
		
			
				
					          class="w-full max-w-lg mx-auto" 
			
		
	
		
		
			
				
					          @detect="onScanDetect" 
			
		
	
		
		
			
				
					          @error="onScanError" 
			
		
	
		
		
			
				
					        /> 
			
		
	
		
		
			
				
					      </div> 
			
		
	
		
		
			
				
					      <div v-else> 
			
		
	
		
		
			
				
					        <!-- Mobile camera button --> 
			
		
	
		
		
			
				
					      </div> 
			
		
	
		
		
			
				
					    </div> 
			
		
	
		
		
			
				
					  </div> 
			
		
	
		
		
			
				
					</template> 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					<script lang="ts"> 
			
		
	
		
		
			
				
					@Component({ 
			
		
	
		
		
			
				
					  components: { QrcodeStream } 
			
		
	
		
		
			
				
					}) 
			
		
	
		
		
			
				
					export default class QRScannerDialog extends Vue { 
			
		
	
		
		
			
				
					  // Implementation... 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					</script> 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Usage Example 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					```typescript 
			
		
	
		
		
			
				
					// In your component 
			
		
	
		
		
			
				
					async function scanQRCode() { 
			
		
	
		
		
			
				
					  const scanner = QRScannerFactory.getInstance(); 
			
		
	
		
		
			
				
					   
			
		
	
		
		
			
				
					  if (!(await scanner.checkPermissions())) { 
			
		
	
		
		
			
				
					    const granted = await scanner.requestPermissions(); 
			
		
	
		
		
			
				
					    if (!granted) { 
			
		
	
		
		
			
				
					      throw new Error('Camera permission denied'); 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
	
		
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  scanner.addListener({  async startScan() { 
			
				
				
			
		
	
		
		
			
				
					
					    onScan: (result) => {    if (this.isScanning) return; 
			
				
				
			
		
	
		
		
			
				
					
					      console.log('Scanned:', result);    this.isScanning = true; 
			
				
				
			
		
	
		
		
			
				
					    }, 
			
		
	
		
		
			
				
					    onError: (error) => { 
			
		
	
		
		
			
				
					      console.error('Scan error:', error); 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  }); 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  await scanner.startScan(); 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					// Cleanup when done 
			
		
	
		
		
			
				
					onUnmounted(() => { 
			
		
	
		
		
			
				
					  QRScannerFactory.cleanup(); 
			
		
	
		
		
			
				
					}); 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Platform-Specific Notes 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					### Mobile (Capacitor) 
			
		
	
		
		
			
				
					- Uses MLKit for optimal performance 
			
		
	
		
		
			
				
					- Handles native permissions 
			
		
	
		
		
			
				
					- Supports both iOS and Android 
			
		
	
		
		
			
				
					- Uses back camera by default 
			
		
	
		
		
			
				
					- Handles device rotation 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					### Web 
			
		
	
		
		
			
				
					- Uses MediaDevices API 
			
		
	
		
		
			
				
					- Requires HTTPS for camera access 
			
		
	
		
		
			
				
					- Handles browser compatibility 
			
		
	
		
		
			
				
					- Manages memory and resources 
			
		
	
		
		
			
				
					- Provides fallback UI 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Testing 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					1. **Unit Tests** 
			
		
	
		
		
			
				
					- Test factory pattern 
			
		
	
		
		
			
				
					- Test platform detection 
			
		
	
		
		
			
				
					- Test error handling 
			
		
	
		
		
			
				
					- Test cleanup procedures 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					2. **Integration Tests** 
			
		
	
		
		
			
				
					- Test permission flows 
			
		
	
		
		
			
				
					- Test camera access 
			
		
	
		
		
			
				
					- Test QR code detection 
			
		
	
		
		
			
				
					- Test cross-platform behavior 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					3. **E2E Tests** 
			
		
	
		
		
			
				
					- Test full scanning workflow 
			
		
	
		
		
			
				
					- Test UI feedback 
			
		
	
		
		
			
				
					- Test error scenarios 
			
		
	
		
		
			
				
					- Test platform differences 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Common Issues and Solutions 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					1. **Permission Handling** 
			
		
	
		
		
			
				
					- Always check permissions first 
			
		
	
		
		
			
				
					- Provide clear user feedback 
			
		
	
		
		
			
				
					- Handle denial gracefully 
			
		
	
		
		
			
				
					- Implement retry logic 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					2. **Resource Management** 
			
		
	
		
		
			
				
					- Clean up after scanning 
			
		
	
		
		
			
				
					- Handle component unmounting 
			
		
	
		
		
			
				
					- Release camera resources 
			
		
	
		
		
			
				
					- Clear event listeners 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					3. **Error Handling** 
			
		
	
		
		
			
				
					- Log errors appropriately 
			
		
	
		
		
			
				
					- Provide user feedback 
			
		
	
		
		
			
				
					- Implement fallbacks 
			
		
	
		
		
			
				
					- Handle edge cases 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					4. **Performance** 
			
		
	
		
		
			
				
					- Optimize camera preview 
			
		
	
		
		
			
				
					- Handle memory usage 
			
		
	
		
		
			
				
					- Manage battery impact 
			
		
	
		
		
			
				
					- Consider device capabilities 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					# QR Code Implementation Guide 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Directory Structure 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					src/ 
			
		
	
		
		
			
				
					├── components/ 
			
		
	
		
		
			
				
					│   └── QRScanner/ 
			
		
	
		
		
			
				
					│       ├── types.ts 
			
		
	
		
		
			
				
					│       ├── factory.ts 
			
		
	
		
		
			
				
					│       ├── CapacitorScanner.ts 
			
		
	
		
		
			
				
					│       ├── WebDialogScanner.ts 
			
		
	
		
		
			
				
					│       └── QRScannerDialog.vue 
			
		
	
		
		
			
				
					├── services/ 
			
		
	
		
		
			
				
					│   └── QRScanner/ 
			
		
	
		
		
			
				
					│       ├── types.ts 
			
		
	
		
		
			
				
					│       ├── QRScannerFactory.ts 
			
		
	
		
		
			
				
					│       ├── CapacitorQRScanner.ts 
			
		
	
		
		
			
				
					│       └── WebDialogQRScanner.ts 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Core Interfaces 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					```typescript 
			
		
	
		
		
			
				
					// types.ts 
			
		
	
		
		
			
				
					export interface ScanListener { 
			
		
	
		
		
			
				
					  onScan: (result: string) => void; 
			
		
	
		
		
			
				
					  onError?: (error: Error) => void; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					export interface QRScannerService { 
			
		
	
		
		
			
				
					  checkPermissions(): Promise<boolean>; 
			
		
	
		
		
			
				
					  requestPermissions(): Promise<boolean>; 
			
		
	
		
		
			
				
					  isSupported(): Promise<boolean>; 
			
		
	
		
		
			
				
					  startScan(): Promise<void>; 
			
		
	
		
		
			
				
					  stopScan(): Promise<void>; 
			
		
	
		
		
			
				
					  addListener(listener: ScanListener): void; 
			
		
	
		
		
			
				
					  cleanup(): Promise<void>; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Configuration Files 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					### Vite Configuration 
			
		
	
		
		
			
				
					```typescript 
			
		
	
		
		
			
				
					// vite.config.ts 
			
		
	
		
		
			
				
					export default defineConfig({ 
			
		
	
		
		
			
				
					  define: { 
			
		
	
		
		
			
				
					    __USE_QR_READER__: JSON.stringify(!isMobile), 
			
		
	
		
		
			
				
					    __IS_MOBILE__: JSON.stringify(isMobile), 
			
		
	
		
		
			
				
					  }, 
			
		
	
		
		
			
				
					  build: { 
			
		
	
		
		
			
				
					    rollupOptions: { 
			
		
	
		
		
			
				
					      external: isMobile ? ['vue-qrcode-reader'] : [], 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					}); 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					### Capacitor Configuration    try { 
			
				
				
			
		
	
		
		
			
				
					
					```typescript      await BarcodeScanner.startScan(); 
			
				
				
			
		
	
		
		
			
				
					
					// capacitor.config.ts    } catch (error) { 
			
				
				
			
		
	
		
		
			
				
					
					const config: CapacitorConfig = {      this.isScanning = false; 
			
				
				
			
		
	
		
		
			
				
					
					  plugins: {      throw error; 
			
				
				
			
		
	
		
		
			
				
					    MLKitBarcodeScanner: { 
			
		
	
		
		
			
				
					      formats: ['QR_CODE'], 
			
		
	
		
		
			
				
					      detectorSize: 1.0, 
			
		
	
		
		
			
				
					      lensFacing: 'back', 
			
		
	
		
		
			
				
					      googleBarcodeScannerModuleInstallState: true 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					}; 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Implementation Steps 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					1. **Install Dependencies** 
			
		
	
		
		
			
				
					```bash 
			
		
	
		
		
			
				
					npm install @capacitor-mlkit/barcode-scanning vue-qrcode-reader 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					2. **Create Core Types**  async stopScan() { 
			
				
				
			
		
	
		
		
			
				
					
					Create the interface files as shown above.    if (!this.isScanning) return; 
			
				
				
			
		
	
		
		
			
				
					
					
    this.isScanning = false; 
			
				
				
			
		
	
		
		
			
				
					3. **Implement Factory** 
			
		
	
		
		
			
				
					```typescript 
			
		
	
		
		
			
				
					// QRScannerFactory.ts 
			
		
	
		
		
			
				
					export class QRScannerFactory { 
			
		
	
		
		
			
				
					  private static instance: QRScannerService | null = null; 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  static getInstance(): QRScannerService {    try { 
			
				
				
			
		
	
		
		
			
				
					
					    if (!this.instance) {      await BarcodeScanner.stopScan(); 
			
				
				
			
		
	
		
		
			
				
					
					      if (__IS_MOBILE__ || Capacitor.isNativePlatform()) {    } catch (error) { 
			
				
				
			
		
	
		
		
			
				
					
					        this.instance = new CapacitorQRScanner();      logger.error('Error stopping scan:', error); 
			
				
				
			
		
	
		
		
			
				
					      } else if (__USE_QR_READER__) { 
			
		
	
		
		
			
				
					        this.instance = new WebDialogQRScanner(); 
			
		
	
		
		
			
				
					      } else { 
			
		
	
		
		
			
				
					        throw new Error('No QR scanner implementation available'); 
			
		
	
		
		
			
				
					      } 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					    return this.instance; 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  static async cleanup() {  addListener(listener: ScanListener) { 
			
				
				
			
		
	
		
		
			
				
					
					    if (this.instance) {    this.scanListener = listener; 
			
				
				
			
		
	
		
		
			
				
					
					      await this.instance.cleanup();    const handle = BarcodeScanner.addListener('barcodeScanned', (result) => { 
			
				
				
			
		
	
		
		
			
				
					
					      this.instance = null;      if (this.scanListener) { 
			
				
				
			
		
	
		
		
			
				
					
					    }        this.scanListener.onScan(result.barcode); 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					      } 
			
		
	
		
		
			
				
					    }); 
			
		
	
		
		
			
				
					    this.listenerHandles.push(handle.remove); 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					``` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					4. **Implement Mobile Scanner**  async cleanup() { 
			
				
				
			
		
	
		
		
			
				
					
					```typescript    await this.stopScan(); 
			
				
				
			
		
	
		
		
			
				
					
					// CapacitorQRScanner.ts    for (const handle of this.listenerHandles) { 
			
				
				
			
		
	
		
		
			
				
					
					export class CapacitorQRScanner implements QRScannerService {      await handle(); 
			
				
				
			
		
	
		
		
			
				
					  private scanListener: ScanListener | null = null; 
			
		
	
		
		
			
				
					  private isScanning = false; 
			
		
	
		
		
			
				
					  private listenerHandles: Array<() => Promise<void>> = []; 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async checkPermissions() { 
			
		
	
		
		
			
				
					    try { 
			
		
	
		
		
			
				
					      const { camera } = await BarcodeScanner.checkPermissions(); 
			
		
	
		
		
			
				
					      return camera === 'granted'; 
			
		
	
		
		
			
				
					    } catch (error) { 
			
		
	
		
		
			
				
					      logger.error('Error checking camera permissions:', error); 
			
		
	
		
		
			
				
					      return false; 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					    this.listenerHandles = []; 
			
		
	
		
		
			
				
					    this.scanListener = null; 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  // Implement other interface methods... 
			
		
	
		
		
			
				
					}} 
			
		
	
		
		
			
				
					`````` 
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -426,6 +198,7 @@ export class WebDialogQRScanner implements QRScannerService { 
			
		
	
		
		
			
				
					  private dialogInstance: App | null = null;  private dialogInstance: App | null = null; 
			
		
	
		
		
			
				
					  private dialogComponent: InstanceType<typeof QRScannerDialog> | null = null;  private dialogComponent: InstanceType<typeof QRScannerDialog> | null = null; 
			
		
	
		
		
			
				
					  private scanListener: ScanListener | null = null;  private scanListener: ScanListener | null = null; 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async checkPermissions(): Promise<boolean> {  async checkPermissions(): Promise<boolean> { 
			
		
	
		
		
			
				
					    try {    try { 
			
		
	
		
		
			
				
					      const permissions = await navigator.permissions.query({      const permissions = await navigator.permissions.query({ 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -438,7 +211,61 @@ export class WebDialogQRScanner implements QRScannerService { 
			
		
	
		
		
			
				
					    }    } 
			
		
	
		
		
			
				
					  }  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					
					  // Implement other interface methods...  async requestPermissions(): Promise<boolean> { 
			
				
				
			
		
	
		
		
	
		
		
			
				
					    try { 
			
		
	
		
		
			
				
					      const stream = await navigator.mediaDevices.getUserMedia({ video: true }); 
			
		
	
		
		
			
				
					      stream.getTracks().forEach(track => track.stop()); 
			
		
	
		
		
			
				
					      return true; 
			
		
	
		
		
			
				
					    } catch (error) { 
			
		
	
		
		
			
				
					      logger.error('Error requesting camera permissions:', error); 
			
		
	
		
		
			
				
					      return false; 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async isSupported(): Promise<boolean> { 
			
		
	
		
		
			
				
					    return 'mediaDevices' in navigator && 'getUserMedia' in navigator.mediaDevices; 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async startScan() { 
			
		
	
		
		
			
				
					    if (this.dialogInstance) return; 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    const container = document.createElement('div'); 
			
		
	
		
		
			
				
					    document.body.appendChild(container); 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    this.dialogInstance = createApp(QRScannerDialog, { 
			
		
	
		
		
			
				
					      onScan: (result: string) => { 
			
		
	
		
		
			
				
					        if (this.scanListener) { 
			
		
	
		
		
			
				
					          this.scanListener.onScan(result); 
			
		
	
		
		
			
				
					        } 
			
		
	
		
		
			
				
					      }, 
			
		
	
		
		
			
				
					      onError: (error: Error) => { 
			
		
	
		
		
			
				
					        if (this.scanListener?.onError) { 
			
		
	
		
		
			
				
					          this.scanListener.onError(error); 
			
		
	
		
		
			
				
					        } 
			
		
	
		
		
			
				
					      }, 
			
		
	
		
		
			
				
					      onClose: () => { 
			
		
	
		
		
			
				
					        this.cleanup(); 
			
		
	
		
		
			
				
					      } 
			
		
	
		
		
			
				
					    }); 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    this.dialogComponent = this.dialogInstance.mount(container) as InstanceType<typeof QRScannerDialog>; 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async stopScan() { 
			
		
	
		
		
			
				
					    await this.cleanup(); 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  addListener(listener: ScanListener) { 
			
		
	
		
		
			
				
					    this.scanListener = listener; 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  async cleanup() { 
			
		
	
		
		
			
				
					    if (this.dialogInstance) { 
			
		
	
		
		
			
				
					      this.dialogInstance.unmount(); 
			
		
	
		
		
			
				
					      this.dialogInstance = null; 
			
		
	
		
		
			
				
					      this.dialogComponent = null; 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					}} 
			
		
	
		
		
			
				
					`````` 
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -448,29 +275,125 @@ export class WebDialogQRScanner implements QRScannerService { 
			
		
	
		
		
			
				
					<template><template> 
			
		
	
		
		
			
				
					  <div v-if="visible" class="dialog-overlay z-[60]">  <div v-if="visible" class="dialog-overlay z-[60]"> 
			
		
	
		
		
			
				
					    <div class="dialog relative">    <div class="dialog relative"> 
			
		
	
		
		
			
				
					
					      <!-- Dialog content -->      <div class="dialog-header"> 
			
				
				
			
		
	
		
		
			
				
					
					      <div v-if="useQRReader">        <h2>Scan QR Code</h2> 
			
				
				
			
		
	
		
		
			
				
					
					        <qrcode-stream        <button @click="onClose" class="close-button">×</button> 
			
				
				
			
		
	
		
		
			
				
					          class="w-full max-w-lg mx-auto" 
			
		
	
		
		
			
				
					          @detect="onScanDetect" 
			
		
	
		
		
			
				
					          @error="onScanError" 
			
		
	
		
		
			
				
					        /> 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					      </div>      </div> 
			
		
	
		
		
			
				
					
					      <div v-else>      <div class="dialog-content"> 
			
				
				
			
		
	
		
		
			
				
					
					        <!-- Mobile camera button -->        <div v-if="useQRReader"> 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					          <qrcode-stream 
			
		
	
		
		
			
				
					            class="w-full max-w-lg mx-auto" 
			
		
	
		
		
			
				
					            @detect="onScanDetect" 
			
		
	
		
		
			
				
					            @error="onScanError" 
			
		
	
		
		
			
				
					          /> 
			
		
	
		
		
			
				
					        </div> 
			
		
	
		
		
			
				
					        <div v-else> 
			
		
	
		
		
			
				
					          <button @click="startMobileScan" class="scan-button"> 
			
		
	
		
		
			
				
					            Start Camera 
			
		
	
		
		
			
				
					          </button> 
			
		
	
		
		
			
				
					        </div> 
			
		
	
		
		
			
				
					      </div>      </div> 
			
		
	
		
		
			
				
					    </div>    </div> 
			
		
	
		
		
			
				
					  </div>  </div> 
			
		
	
		
		
			
				
					</template></template> 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					<script lang="ts"><script lang="ts"> 
			
		
	
		
		
			
				
					
					@Component({import { defineComponent } from 'vue'; 
			
				
				
			
		
	
		
		
			
				
					
					  components: { QrcodeStream }import { QrcodeStream } from 'vue-qrcode-reader'; 
			
				
				
			
		
	
		
		
			
				
					
					})
 
			
				
				
			
		
	
		
		
			
				
					
					export default class QRScannerDialog extends Vue {export default defineComponent({ 
			
				
				
			
		
	
		
		
			
				
					
					  // Implementation...  name: 'QRScannerDialog', 
			
				
				
			
		
	
		
		
			
				
					
					}  components: { QrcodeStream }, 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					  props: { 
			
		
	
		
		
			
				
					    onScan: { 
			
		
	
		
		
			
				
					      type: Function, 
			
		
	
		
		
			
				
					      required: true 
			
		
	
		
		
			
				
					    }, 
			
		
	
		
		
			
				
					    onError: { 
			
		
	
		
		
			
				
					      type: Function, 
			
		
	
		
		
			
				
					      required: true 
			
		
	
		
		
			
				
					    }, 
			
		
	
		
		
			
				
					    onClose: { 
			
		
	
		
		
			
				
					      type: Function, 
			
		
	
		
		
			
				
					      required: true 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  }, 
			
		
	
		
		
			
				
					  data() { 
			
		
	
		
		
			
				
					    return { 
			
		
	
		
		
			
				
					      visible: true, 
			
		
	
		
		
			
				
					      useQRReader: __USE_QR_READER__ 
			
		
	
		
		
			
				
					    }; 
			
		
	
		
		
			
				
					  }, 
			
		
	
		
		
			
				
					  methods: { 
			
		
	
		
		
			
				
					    onScanDetect(promisedResult: Promise<string>) { 
			
		
	
		
		
			
				
					      promisedResult 
			
		
	
		
		
			
				
					        .then(result => this.onScan(result)) 
			
		
	
		
		
			
				
					        .catch(error => this.onError(error)); 
			
		
	
		
		
			
				
					    }, 
			
		
	
		
		
			
				
					    onScanError(error: Error) { 
			
		
	
		
		
			
				
					      this.onError(error); 
			
		
	
		
		
			
				
					    }, 
			
		
	
		
		
			
				
					    async startMobileScan() { 
			
		
	
		
		
			
				
					      try { 
			
		
	
		
		
			
				
					        const scanner = QRScannerFactory.getInstance(); 
			
		
	
		
		
			
				
					        await scanner.startScan(); 
			
		
	
		
		
			
				
					      } catch (error) { 
			
		
	
		
		
			
				
					        this.onError(error as Error); 
			
		
	
		
		
			
				
					      } 
			
		
	
		
		
			
				
					    } 
			
		
	
		
		
			
				
					  } 
			
		
	
		
		
			
				
					}); 
			
		
	
		
		
			
				
					</script></script> 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					<style scoped> 
			
		
	
		
		
			
				
					.dialog-overlay { 
			
		
	
		
		
			
				
					  position: fixed; 
			
		
	
		
		
			
				
					  top: 0; 
			
		
	
		
		
			
				
					  left: 0; 
			
		
	
		
		
			
				
					  right: 0; 
			
		
	
		
		
			
				
					  bottom: 0; 
			
		
	
		
		
			
				
					  background: rgba(0, 0, 0, 0.5); 
			
		
	
		
		
			
				
					  display: flex; 
			
		
	
		
		
			
				
					  align-items: center; 
			
		
	
		
		
			
				
					  justify-content: center; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					.dialog { 
			
		
	
		
		
			
				
					  background: white; 
			
		
	
		
		
			
				
					  border-radius: 8px; 
			
		
	
		
		
			
				
					  padding: 20px; 
			
		
	
		
		
			
				
					  max-width: 90vw; 
			
		
	
		
		
			
				
					  max-height: 90vh; 
			
		
	
		
		
			
				
					  overflow: auto; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					.dialog-header { 
			
		
	
		
		
			
				
					  display: flex; 
			
		
	
		
		
			
				
					  justify-content: space-between; 
			
		
	
		
		
			
				
					  align-items: center; 
			
		
	
		
		
			
				
					  margin-bottom: 20px; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					.close-button { 
			
		
	
		
		
			
				
					  background: none; 
			
		
	
		
		
			
				
					  border: none; 
			
		
	
		
		
			
				
					  font-size: 24px; 
			
		
	
		
		
			
				
					  cursor: pointer; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					.scan-button { 
			
		
	
		
		
			
				
					  background: #4CAF50; 
			
		
	
		
		
			
				
					  color: white; 
			
		
	
		
		
			
				
					  padding: 10px 20px; 
			
		
	
		
		
			
				
					  border: none; 
			
		
	
		
		
			
				
					  border-radius: 4px; 
			
		
	
		
		
			
				
					  cursor: pointer; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					.scan-button:hover { 
			
		
	
		
		
			
				
					  background: #45a049; 
			
		
	
		
		
			
				
					} 
			
		
	
		
		
			
				
					</style> 
			
		
	
		
		
			
				
					`````` 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Usage Example## Usage Example 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -513,6 +436,7 @@ onUnmounted(() => { 
			
		
	
		
		
			
				
					- Supports both iOS and Android- Supports both iOS and Android 
			
		
	
		
		
			
				
					- Uses back camera by default- Uses back camera by default 
			
		
	
		
		
			
				
					- Handles device rotation- Handles device rotation 
			
		
	
		
		
			
				
					- Provides native UI for scanning 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					### Web### Web 
			
		
	
		
		
			
				
					- Uses MediaDevices API- Uses MediaDevices API 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -520,6 +444,7 @@ onUnmounted(() => { 
			
		
	
		
		
			
				
					- Handles browser compatibility- Handles browser compatibility 
			
		
	
		
		
			
				
					- Manages memory and resources- Manages memory and resources 
			
		
	
		
		
			
				
					- Provides fallback UI- Provides fallback UI 
			
		
	
		
		
			
				
					- Uses vue-qrcode-reader for web scanning 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Testing## Testing 
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -528,41 +453,74 @@ onUnmounted(() => { 
			
		
	
		
		
			
				
					- Test platform detection- Test platform detection 
			
		
	
		
		
			
				
					- Test error handling- Test error handling 
			
		
	
		
		
			
				
					- Test cleanup procedures- Test cleanup procedures 
			
		
	
		
		
			
				
					- Test permission flows 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					2. **Integration Tests**2. **Integration Tests** 
			
		
	
		
		
			
				
					- Test permission flows 
			
		
	
		
		
			
				
					- Test camera access- Test camera access 
			
		
	
		
		
			
				
					- Test QR code detection- Test QR code detection 
			
		
	
		
		
			
				
					- Test cross-platform behavior- Test cross-platform behavior 
			
		
	
		
		
			
				
					- Test UI components 
			
		
	
		
		
			
				
					- Test error scenarios 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					3. **E2E Tests**3. **E2E Tests** 
			
		
	
		
		
			
				
					
					- Test full scanning workflow- Test complete scanning flow 
			
				
				
			
		
	
		
		
			
				
					
					- Test UI feedback- Test permission handling 
			
				
				
			
		
	
		
		
			
				
					
					- Test error scenarios- Test cross-platform compatibility 
			
				
				
			
		
	
		
		
			
				
					
					- Test platform differences- Test error recovery 
			
				
				
			
		
	
		
		
			
				
					
					
- Test cleanup procedures 
			
				
				
			
		
	
		
		
			
				
					
					## Common Issues and Solutions
 
			
				
				
			
		
	
		
		
			
				
					
					
## Best Practices 
			
				
				
			
		
	
		
		
			
				
					
					1. **Permission Handling**
 
			
				
				
			
		
	
		
		
			
				
					
					- Always check permissions first1. **Error Handling** 
			
				
				
			
		
	
		
		
			
				
					
					- Provide clear user feedback- Always handle permission errors gracefully 
			
				
				
			
		
	
		
		
			
				
					
					- Handle denial gracefully- Provide clear error messages to users 
			
				
				
			
		
	
		
		
			
				
					
					- Implement retry logic- Implement proper cleanup on errors 
			
				
				
			
		
	
		
		
			
				
					
					
- Log errors for debugging 
			
				
				
			
		
	
		
		
			
				
					
					2. **Resource Management**
 
			
				
				
			
		
	
		
		
			
				
					
					- Clean up after scanning2. **Performance** 
			
				
				
			
		
	
		
		
			
				
					
					- Handle component unmounting- Clean up resources when not in use 
			
				
				
			
		
	
		
		
			
				
					
					- Release camera resources- Handle device rotation properly 
			
				
				
			
		
	
		
		
			
				
					
					- Clear event listeners- Optimize camera usage 
			
				
				
			
		
	
		
		
			
				
					
					
- Manage memory efficiently 
			
				
				
			
		
	
		
		
			
				
					
					3. **Error Handling**
 
			
				
				
			
		
	
		
		
			
				
					
					- Log errors appropriately3. **Security** 
			
				
				
			
		
	
		
		
			
				
					
					- Provide user feedback- Request minimum required permissions 
			
				
				
			
		
	
		
		
			
				
					
					- Implement fallbacks- Handle sensitive data securely 
			
				
				
			
		
	
		
		
			
				
					
					- Handle edge cases- Validate scanned data 
			
				
				
			
		
	
		
		
			
				
					
					
- Implement proper cleanup 
			
				
				
			
		
	
		
		
			
				
					
					4. **Performance**
 
			
				
				
			
		
	
		
		
			
				
					
					- Optimize camera preview4. **User Experience** 
			
				
				
			
		
	
		
		
			
				
					
					- Handle memory usage- Provide clear feedback 
			
				
				
			
		
	
		
		
			
				
					
					- Manage battery impact- Handle edge cases gracefully 
			
				
				
			
		
	
		
		
			
				
					
					- Consider device capabilities- Support both platforms seamlessly 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					- Implement proper loading states 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Troubleshooting 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					1. **Common Issues** 
			
		
	
		
		
			
				
					- Camera permissions denied 
			
		
	
		
		
			
				
					- Device not supported 
			
		
	
		
		
			
				
					- Scanner not working 
			
		
	
		
		
			
				
					- Memory leaks 
			
		
	
		
		
			
				
					- UI glitches 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					2. **Solutions** 
			
		
	
		
		
			
				
					- Check permissions 
			
		
	
		
		
			
				
					- Verify device support 
			
		
	
		
		
			
				
					- Debug scanner implementation 
			
		
	
		
		
			
				
					- Monitor memory usage 
			
		
	
		
		
			
				
					- Test UI components 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					## Maintenance 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					1. **Regular Updates** 
			
		
	
		
		
			
				
					- Keep dependencies updated 
			
		
	
		
		
			
				
					- Monitor platform changes 
			
		
	
		
		
			
				
					- Update documentation 
			
		
	
		
		
			
				
					- Review security patches 
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					2. **Performance Monitoring** 
			
		
	
		
		
			
				
					- Track memory usage 
			
		
	
		
		
			
				
					- Monitor camera performance 
			
		
	
		
		
			
				
					- Check error rates 
			
		
	
		
		
			
				
					- Analyze user feedback