diff --git a/package.json b/package.json
index 65f29dbd..ab8b3a8e 100644
--- a/package.json
+++ b/package.json
@@ -78,6 +78,7 @@
"pinia": "^2.0.34",
"plausible-tracker": "^0.3.8",
"qrcode": "^1.5.1",
+ "qrcode-parser": "^2.1.3",
"sql-formatter": "^13.0.0",
"ua-parser-js": "^1.0.35",
"ulid": "^2.3.0",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index a6f7c32f..23459c19 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -134,6 +134,9 @@ dependencies:
qrcode:
specifier: ^1.5.1
version: 1.5.1
+ qrcode-parser:
+ specifier: ^2.1.3
+ version: 2.1.3
sql-formatter:
specifier: ^13.0.0
version: 13.0.0
@@ -3341,7 +3344,7 @@ packages:
dependencies:
'@unhead/dom': 0.5.1
'@unhead/schema': 0.5.1
- '@vueuse/shared': 10.7.2(vue@3.3.4)
+ '@vueuse/shared': 10.9.0(vue@3.3.4)
unhead: 0.5.1
vue: 3.3.4
transitivePeerDependencies:
@@ -3983,10 +3986,10 @@ packages:
- vue
dev: false
- /@vueuse/shared@10.7.2(vue@3.3.4):
- resolution: {integrity: sha512-qFbXoxS44pi2FkgFjPvF4h7c9oMDutpyBdcJdMYIMg9XyXli2meFMuaKn+UMgsClo//Th6+beeCgqweT/79BVA==}
+ /@vueuse/shared@10.9.0(vue@3.3.4):
+ resolution: {integrity: sha512-Uud2IWncmAfJvRaFYzv5OHDli+FbOzxiVEQdLCKQKLyhz94PIyFC3CHcH7EDMwIn8NPtD06+PNbC/PiO0LGLtw==}
dependencies:
- vue-demi: 0.14.6(vue@3.3.4)
+ vue-demi: 0.14.7(vue@3.3.4)
transitivePeerDependencies:
- '@vue/composition-api'
- vue
@@ -6595,6 +6598,10 @@ packages:
engines: {node: '>=0.10.0'}
dev: true
+ /jsqr@1.4.0:
+ resolution: {integrity: sha512-dxLob7q65Xg2DvstYkRpkYtmKm2sPJ9oFhrhmudT1dZvNFFTlroai3AWSpLey/w5vMcLBXRgOJsbXpdN9HzU/A==}
+ dev: false
+
/jwt-decode@3.1.2:
resolution: {integrity: sha512-UfpWE/VZn0iP50d8cz9NrZLM9lSWhcJ+0Gt/nm4by88UL+J1SiKN8/5dkjMmbEzwL2CAe+67GsegCbIKtbp75A==}
dev: false
@@ -7657,6 +7664,12 @@ packages:
engines: {node: '>=6'}
dev: true
+ /qrcode-parser@2.1.3:
+ resolution: {integrity: sha512-tyakoHUQXCjH1+RGiqxH3/6XqbQuXuSaW0CkUp1AlYT0+XA4ndG7bxxyyWpdnr0Z2Vuv0GRwgKSq6sOzNiQfog==}
+ dependencies:
+ jsqr: 1.4.0
+ dev: false
+
/qrcode@1.5.1:
resolution: {integrity: sha512-nS8NJ1Z3md8uTjKtP+SGGhfqmTCs5flU/xR623oI0JX+Wepz9R8UrRVCTBTJm3qGw3rH6jJ6MUHjkDx15cxSSg==}
engines: {node: '>=10.13.0'}
@@ -9135,8 +9148,8 @@ packages:
vue: 3.3.4
dev: false
- /vue-demi@0.14.6(vue@3.3.4):
- resolution: {integrity: sha512-8QA7wrYSHKaYgUxDA5ZC24w+eHm3sYCbp0EzcDwKqN3p6HqtTCGR/GVsPyZW92unff4UlcSh++lmqDWN3ZIq4w==}
+ /vue-demi@0.14.7(vue@3.3.4):
+ resolution: {integrity: sha512-EOG8KXDQNwkJILkx/gPcoL/7vH+hORoBaKgGe+6W7VFMvCYJfmF2dGbvgDroVnI8LU7/kTu8mbjRZGBU1z9NTA==}
engines: {node: '>=12'}
hasBin: true
requiresBuild: true
diff --git a/src/tools/index.ts b/src/tools/index.ts
index 2a477ed2..ea2e52f6 100644
--- a/src/tools/index.ts
+++ b/src/tools/index.ts
@@ -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',
diff --git a/src/tools/qr-code-decoder/index.ts b/src/tools/qr-code-decoder/index.ts
new file mode 100644
index 00000000..edb88799
--- /dev/null
+++ b/src/tools/qr-code-decoder/index.ts
@@ -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'),
+});
diff --git a/src/tools/qr-code-decoder/qr-code-decoder.vue b/src/tools/qr-code-decoder/qr-code-decoder.vue
new file mode 100644
index 00000000..27b1ee32
--- /dev/null
+++ b/src/tools/qr-code-decoder/qr-code-decoder.vue
@@ -0,0 +1,47 @@
+
+
+
+
+
+
+
+
+
+
Decoded
+
+
+
+
+
+