import Card from "./Card"; import {saveAs} from 'file-saver' import React, {FormEvent, useEffect, useRef, useState} from "react"; import {BrowserQRCodeReader} from "@zxing/browser"; import {Result} from "@zxing/library"; import {PayloadBody} from "../src/payload"; import {getPayloadBodyFromFile, getPayloadBodyFromQR} from "../src/process"; import {PassData} from "../src/pass"; import Alert from "./Alert"; function Form(): JSX.Element { // Whether camera is open or not const [isCameraOpen, setIsCameraOpen] = useState(false); // Global camera controls const [globalControls, setGlobalControls] = useState(undefined); // Currently selected QR Code / File. Only one of them is set. const [qrCode, setQrCode] = useState(undefined); const [file, setFile] = useState(undefined); const [errorMessage, setErrorMessage] = useState(undefined); const [loading, setLoading] = useState(false); // File Input ref const inputFile = useRef(undefined) // Add event listener to listen for file change events useEffect(() => { if (inputFile && inputFile.current) { inputFile.current.addEventListener('input', () => { let selectedFile = inputFile.current.files[0]; if (selectedFile !== undefined) { setQrCode(undefined); setFile(selectedFile); } }); } }, [inputFile]) // Show file Dialog async function showFileDialog() { inputFile.current.click(); } // Hide camera view async function hideCameraView() { if (globalControls !== undefined) { globalControls.stop(); } setIsCameraOpen(false); } // Show camera view async function showCameraView() { // Create new QR Code Reader const codeReader = new BrowserQRCodeReader(); // Needs to be called before any camera can be accessed await BrowserQRCodeReader.listVideoInputDevices(); // Get preview Element to show camera stream const previewElem: HTMLVideoElement = document.querySelector('#cameraPreview'); // Set Global controls setGlobalControls( // Start decoding from video device await codeReader.decodeFromVideoDevice(undefined, previewElem, (result, error, controls) => { if (result !== undefined) { setQrCode(result); setFile(undefined); controls.stop(); // Reset setGlobalControls(undefined); setIsCameraOpen(false); } } ) ); setIsCameraOpen(true); } // Add Pass to wallet async function addToWallet(event: FormEvent) { event.preventDefault(); setLoading(true); if (!file && !qrCode) { setErrorMessage("Please scan a QR Code, or select a file to scan") setLoading(false); return; } const color = (document.getElementById('color') as HTMLSelectElement).value; let payloadBody: PayloadBody; try { if (file) { payloadBody = await getPayloadBodyFromFile(file, color); } else { payloadBody = await getPayloadBodyFromQR(qrCode, color); } let pass = await PassData.generatePass(payloadBody); const passBlob = new Blob([pass], {type: "application/vnd.apple.pkpass"}); saveAs(passBlob, 'covid.pkpass'); setLoading(false); } catch (e) { setErrorMessage(e.toString()); setLoading(false); } } return (

Please select the certificate screenshot or (scanned) PDF page, which you received from your doctor, pharmacy, vaccination centre or online. Note that taking a picture does not work on most devices yet.

}/>

Pick a background color for your pass.

}/>

Data privacy is of special importance when processing health-related data. In order for you to make an informed decision, please read the Privacy Policy.

}/> { errorMessage && setErrorMessage(undefined)}/> } ) } export default Form;