feat(new tool): QRCode decoder

Fix #656
This commit is contained in:
sharevb 2024-03-03 09:49:14 +01:00 committed by ShareVB
parent a07806cd15
commit 6d619603f9
5 changed files with 87 additions and 7 deletions

View file

@ -2,6 +2,7 @@ import { tool as base64FileConverter } from './base64-file-converter';
import { tool as base64StringConverter } from './base64-string-converter';
import { tool as basicAuthGenerator } from './basic-auth-generator';
import { tool as textToUnicode } from './text-to-unicode';
import { tool as qrCodeDecoder } from './qr-code-decoder';
import { tool as pdfSignatureChecker } from './pdf-signature-checker';
import { tool as numeronymGenerator } from './numeronym-generator';
import { tool as macAddressGenerator } from './mac-address-generator';
@ -127,7 +128,13 @@ export const toolsByCategory: ToolCategory[] = [
},
{
name: 'Images and videos',
components: [qrCodeGenerator, wifiQrCodeGenerator, svgPlaceholderGenerator, cameraRecorder],
components: [
qrCodeGenerator,
wifiQrCodeGenerator,
qrCodeDecoder,
svgPlaceholderGenerator,
cameraRecorder,
],
},
{
name: 'Development',

View file

@ -0,0 +1,12 @@
import { Qrcode } from '@vicons/tabler';
import { defineTool } from '../tool';
export const tool = defineTool({
name: 'QRCode decoder',
path: '/qr-code-decoder',
description: 'QR Code Reader',
keywords: ['qrcode', 'qr-code', 'decoder', 'reader'],
component: () => import('./qr-code-decoder.vue'),
icon: Qrcode,
createdAt: new Date('2024-01-17'),
});

View file

@ -0,0 +1,47 @@
<script setup lang="ts">
import type { Ref } from 'vue';
import qrcodeParser from 'qrcode-parser';
import TextareaCopyable from '@/components/TextareaCopyable.vue';
const fileInput = ref() as Ref<File>;
const qrCode = computedAsync(async () => {
try {
return (await qrcodeParser(fileInput.value));
}
catch (e: any) {
return e.toString();
}
});
async function onUpload(file: File) {
if (file) {
fileInput.value = file;
}
}
</script>
<template>
<div>
<c-file-upload
title="Drag and drop a QR Code here, or click to select a file"
:paste-image="true"
@file-upload="onUpload"
/>
<n-divider />
<div>
<h3>Decoded</h3>
<TextareaCopyable
:value="qrCode"
:word-wrap="true"
/>
</div>
</div>
</template>
<style lang="less" scoped>
::v-deep(.n-upload-trigger) {
width: 100%;
}
</style>