Compare commits
25 Commits
Author | SHA1 | Date |
---|---|---|
![]() |
cfd924beab | 1 year ago |
![]() |
8fb5b98ea2 | 1 year ago |
![]() |
9fa47676df | 3 years ago |
![]() |
0b7edb39df | 3 years ago |
![]() |
8afbcdad33 | 3 years ago |
![]() |
0f2e84268c | 3 years ago |
![]() |
33f115036f | 3 years ago |
![]() |
17ced673e4 | 3 years ago |
![]() |
c236e43f21 | 3 years ago |
![]() |
e6fb08352f | 3 years ago |
![]() |
b9d89e0545 | 3 years ago |
![]() |
aeee33ee6c | 3 years ago |
![]() |
a5cd17b951 | 3 years ago |
![]() |
615081cc95 | 3 years ago |
![]() |
7d77236fc0 | 3 years ago |
![]() |
8c80e312b3 | 4 years ago |
![]() |
6ab5e80028 | 4 years ago |
![]() |
05b1c0d310 | 4 years ago |
![]() |
4161b77272 | 4 years ago |
![]() |
be1f6a980b | 4 years ago |
![]() |
44737ddfe7 | 4 years ago |
![]() |
032f9ba16a | 4 years ago |
![]() |
d1a5b9de6b | 4 years ago |
![]() |
fd6daa86a1 | 4 years ago |
![]() |
b8d25e8969 | 4 years ago |
@ -0,0 +1,108 @@
|
|||||||
|
name: CI
|
||||||
|
|
||||||
|
env:
|
||||||
|
NODE_OPTIONS: --max-old-space-size=6144
|
||||||
|
# install playwright binary manually (because pnpm only runs install script once)
|
||||||
|
PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: "1"
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
- master
|
||||||
|
- release/*
|
||||||
|
- feat/*
|
||||||
|
- fix/*
|
||||||
|
- perf/*
|
||||||
|
- v1
|
||||||
|
- v2
|
||||||
|
pull_request:
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.event.number || github.sha }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
timeout-minutes: 20
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
os: [ubuntu-latest]
|
||||||
|
node_version: [16]
|
||||||
|
fail-fast: false
|
||||||
|
|
||||||
|
name: "Build&Test: node-${{ matrix.node_version }}, ${{ matrix.os }}"
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install pnpm
|
||||||
|
uses: pnpm/action-setup@v2.2.2
|
||||||
|
|
||||||
|
- name: Set node version to ${{ matrix.node_version }}
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node_version }}
|
||||||
|
cache: "pnpm"
|
||||||
|
|
||||||
|
- name: Install deps
|
||||||
|
run: pnpm install
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: pnpm run build
|
||||||
|
|
||||||
|
test:
|
||||||
|
timeout-minutes: 10
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: "Lint: node-16, ubuntu-latest"
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: Install pnpm
|
||||||
|
uses: pnpm/action-setup@v2.2.2
|
||||||
|
|
||||||
|
- name: Set node version to 16
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
cache: "pnpm"
|
||||||
|
|
||||||
|
- name: Install deps
|
||||||
|
run: pnpm install
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: pnpm run build
|
||||||
|
|
||||||
|
- name: Test
|
||||||
|
run: pnpm run test
|
||||||
|
|
||||||
|
lint:
|
||||||
|
timeout-minutes: 10
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
name: "Lint: node-16, ubuntu-latest"
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: Install pnpm
|
||||||
|
uses: pnpm/action-setup@v2.2.2
|
||||||
|
|
||||||
|
- name: Set node version to 16
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
cache: "pnpm"
|
||||||
|
|
||||||
|
- name: Install deps
|
||||||
|
run: pnpm install
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: pnpm run build
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
run: pnpm run prettier
|
@ -1 +1,3 @@
|
|||||||
package-lock=false
|
shamefully-hoist=true
|
||||||
|
strict-peer-dependencies=true
|
||||||
|
auto-install-peers=true
|
||||||
|
@ -0,0 +1,26 @@
|
|||||||
|
import QrcodeDecoder from '../';
|
||||||
|
|
||||||
|
describe('QrcodeDecoder', () => {
|
||||||
|
test('use', async () => {
|
||||||
|
const res = await import('../dist');
|
||||||
|
|
||||||
|
expect(res.default).toEqual(QrcodeDecoder);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('new QrcodeDecoder()', async () => {
|
||||||
|
const qr = new QrcodeDecoder();
|
||||||
|
|
||||||
|
expect(qr).toBeDefined();
|
||||||
|
expect(qr.videoConstraints).toEqual({
|
||||||
|
video: {
|
||||||
|
width: { min: 360, ideal: 720, max: 1080 },
|
||||||
|
height: { min: 360, ideal: 720, max: 1080 },
|
||||||
|
facingMode: { exact: 'environment' },
|
||||||
|
},
|
||||||
|
audio: false,
|
||||||
|
});
|
||||||
|
expect(qr.decodeFromImage).toBeDefined();
|
||||||
|
expect(qr.decodeFromCamera).toBeDefined();
|
||||||
|
expect(qr.decodeFromVideo).toBeDefined();
|
||||||
|
});
|
||||||
|
});
|
@ -1,45 +1,54 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
|
||||||
<title>QrcodeDecoder - Camera</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<button id="start">Start</button> <button id="stop">Stop</button><br />
|
|
||||||
<span id="result">Click start to scan qrcode.</span><br />
|
|
||||||
<hr />
|
|
||||||
<video id="video" autoplay></video>
|
|
||||||
|
|
||||||
<script src="./lib/vconsole.min.js"></script>
|
<head>
|
||||||
<script src="./index.min.js"></script>
|
<meta charset="UTF-8" />
|
||||||
<script type="text/javascript">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
var vConsole = new VConsole();
|
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||||
console.log('Hello world');
|
<title>QrcodeDecoder - Camera</title>
|
||||||
function main() {
|
</head>
|
||||||
var qr = new QrcodeDecoder();
|
|
||||||
var video = document.querySelector('#video');
|
|
||||||
var start = document.querySelector('#start');
|
|
||||||
var stop = document.querySelector('#stop');
|
|
||||||
var result = document.querySelector('#result');
|
|
||||||
async function startScan() {
|
|
||||||
if (!qr.isCanvasSupported()) {
|
|
||||||
alert("Your browser doesn't match the required specs.");
|
|
||||||
throw new Error('Canvas and getUserMedia are required');
|
|
||||||
}
|
|
||||||
|
|
||||||
let code = await qr.decodeFromCamera(video);
|
<body>
|
||||||
console.log('code', code);
|
<button id="start">Start</button> <button id="stop">Stop</button><br />
|
||||||
result.innerText = 'Result: ' + code.data;
|
<span id="result">Click start to scan qrcode.</span><br />
|
||||||
|
<hr />
|
||||||
|
<video id="video" autoplay></video>
|
||||||
|
|
||||||
|
<script src="./lib/vconsole.min.js"></script>
|
||||||
|
<script src="./lib/index.min.js"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
var vConsole = new VConsole();
|
||||||
|
console.log('Hello world');
|
||||||
|
function main() {
|
||||||
|
var qr = new QrcodeDecoder.default();
|
||||||
|
var video = document.querySelector('#video');
|
||||||
|
var start = document.querySelector('#start');
|
||||||
|
var stop = document.querySelector('#stop');
|
||||||
|
var result = document.querySelector('#result');
|
||||||
|
async function startScan() {
|
||||||
|
if (!qr.isCanvasSupported()) {
|
||||||
|
alert("Your browser doesn't match the required specs.");
|
||||||
|
throw new Error('Canvas and getUserMedia are required');
|
||||||
}
|
}
|
||||||
start.onclick = startScan;
|
|
||||||
|
|
||||||
stop.onclick = function() {
|
let code = await qr.decodeFromCamera(video,
|
||||||
qr.stop();
|
// you can customize your camera size like below
|
||||||
};
|
// {
|
||||||
|
// width: 400,
|
||||||
|
// height: 400,
|
||||||
|
// }
|
||||||
|
);
|
||||||
|
console.log('code', code);
|
||||||
|
result.innerText = 'Result: ' + code.data;
|
||||||
}
|
}
|
||||||
main();
|
start.onclick = startScan;
|
||||||
</script>
|
|
||||||
</body>
|
stop.onclick = function () {
|
||||||
|
qr.stop();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
main();
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
@ -1,61 +1,66 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
|
||||||
<title>QrcodeDecoder - Image</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<section>
|
|
||||||
<h3>Same domain image</h3>
|
|
||||||
<img src="./assets/qrcode.png" alt="qr code" /><br />
|
|
||||||
<button id="decode1">Decode!</button><br />
|
|
||||||
<span id="result1"></span><br />
|
|
||||||
</section>
|
|
||||||
<hr />
|
|
||||||
<section>
|
|
||||||
<h3>Different domain image</h3>
|
|
||||||
<button id="decode2">Decode!</button><br />
|
|
||||||
<span id="result2"></span><br />
|
|
||||||
</section>
|
|
||||||
<script src="./lib/vconsole.min.js"></script>
|
|
||||||
<script src="./index.min.js"></script>
|
|
||||||
<script src="./index.min.js"></script>
|
|
||||||
<script type="module">
|
|
||||||
var vConsole = new VConsole();
|
|
||||||
console.log('Hello world');
|
|
||||||
function main() {
|
|
||||||
var qr = new QrcodeDecoder();
|
|
||||||
|
|
||||||
var btn1 = document.querySelector('button#decode1');
|
<head>
|
||||||
var btn2 = document.querySelector('button#decode2');
|
<meta charset="UTF-8" />
|
||||||
var result1 = document.querySelector('#result1');
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
var result2 = document.querySelector('#result2');
|
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||||
var img = document.querySelector('img');
|
<title>QrcodeDecoder - Image</title>
|
||||||
|
</head>
|
||||||
|
|
||||||
btn1.onclick = async () => {
|
<body>
|
||||||
// you can also decode from image path
|
<section>
|
||||||
// const code = await qr.decodeFromImage('./assets/qrcode.png');
|
<h3>Same domain image</h3>
|
||||||
const code = await qr.decodeFromImage(img);
|
<img id="img1" src="./assets/qrcode.png" alt="qr code" /><br />
|
||||||
console.log(code);
|
<button id="decode1">Decode!</button><br />
|
||||||
result1.innerText = code.data;
|
<span id="result1"></span><br />
|
||||||
};
|
</section>
|
||||||
|
<hr />
|
||||||
|
<section>
|
||||||
|
<h3>Different domain image</h3>
|
||||||
|
<input
|
||||||
|
id="img2"
|
||||||
|
value="https://yugasun.com/static/wechat.jpg"
|
||||||
|
style="width: 400px" /><br />
|
||||||
|
<button id="decode2">Decode!</button><br />
|
||||||
|
<span id="result2"></span><br />
|
||||||
|
</section>
|
||||||
|
<script src="./lib/vconsole.min.js"></script>
|
||||||
|
<script src="./lib/index.min.js"></script>
|
||||||
|
<script type="module">
|
||||||
|
var vConsole = new VConsole();
|
||||||
|
function main() {
|
||||||
|
var qr = new QrcodeDecoder.default();
|
||||||
|
|
||||||
btn2.onclick = async () => {
|
var btn1 = document.querySelector('button#decode1');
|
||||||
// you can also decode from image path
|
var btn2 = document.querySelector('button#decode2');
|
||||||
// const code = await qr.decodeFromImage('./assets/qrcode.png');
|
var result1 = document.querySelector('#result1');
|
||||||
const code = await qr.decodeFromImage(
|
var result2 = document.querySelector('#result2');
|
||||||
'https://yugasun.com/static/wechat.jpg',
|
var img1 = document.querySelector('#img1');
|
||||||
{
|
var img2 = document.querySelector('#img2');
|
||||||
crossOrigin: 'anonymous',
|
|
||||||
},
|
btn1.onclick = async () => {
|
||||||
);
|
// you can also decode from image path
|
||||||
console.log(code);
|
// const code = await qr.decodeFromImage('./assets/qrcode.png');
|
||||||
result2.innerText = code.data;
|
const code = await qr.decodeFromImage(img1);
|
||||||
};
|
console.log(code);
|
||||||
}
|
result1.innerText = code.data;
|
||||||
|
};
|
||||||
|
|
||||||
|
btn2.onclick = async () => {
|
||||||
|
// you can also decode from image path
|
||||||
|
// const code = await qr.decodeFromImage('./assets/qrcode.png');
|
||||||
|
const code = await qr.decodeFromImage(img2.value, {
|
||||||
|
crossOrigin: 'anonymous',
|
||||||
|
});
|
||||||
|
console.log(code);
|
||||||
|
result2.innerText = code.data;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
window.onload = () => {
|
||||||
main();
|
main();
|
||||||
</script>
|
};
|
||||||
</body>
|
</script>
|
||||||
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
File diff suppressed because one or more lines are too long
@ -1,43 +1,45 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
|
||||||
<title>QrcodeDecoder - Video</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<button id="start">Start</button> <button id="stop">Stop</button><br />
|
|
||||||
<span id="result">Click start to scan qrcode.</span><br />
|
|
||||||
|
|
||||||
<video src="./assets/qrcode-video.mp4"></video>
|
<head>
|
||||||
<script src="./lib/vconsole.min.js"></script>
|
<meta charset="UTF-8" />
|
||||||
<script src="./index.min.js"></script>
|
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||||
<script type="text/javascript">
|
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
|
||||||
var vConsole = new VConsole();
|
<title>QrcodeDecoder - Video</title>
|
||||||
console.log('Hello world');
|
</head>
|
||||||
function main() {
|
|
||||||
var video = document.querySelector('video');
|
|
||||||
var result = document.querySelector('#result');
|
|
||||||
var start = document.querySelector('#start');
|
|
||||||
var stop = document.querySelector('#stop');
|
|
||||||
var qr = new QrcodeDecoder();
|
|
||||||
|
|
||||||
start.onclick = startScan;
|
<body>
|
||||||
|
<button id="start">Start</button> <button id="stop">Stop</button><br />
|
||||||
|
<span id="result">Click start to scan qrcode.</span><br />
|
||||||
|
|
||||||
stop.onclick = function() {
|
<video src="./assets/qrcode-video.mp4"></video>
|
||||||
qr.stop();
|
<script src="./lib/vconsole.min.js"></script>
|
||||||
video.pause();
|
<script src="./lib/index.min.js"></script>
|
||||||
};
|
<script type="text/javascript">
|
||||||
|
var vConsole = new VConsole();
|
||||||
|
function main() {
|
||||||
|
var video = document.querySelector('video');
|
||||||
|
var result = document.querySelector('#result');
|
||||||
|
var start = document.querySelector('#start');
|
||||||
|
var stop = document.querySelector('#stop');
|
||||||
|
var qr = new QrcodeDecoder.default();
|
||||||
|
|
||||||
async function startScan() {
|
start.onclick = startScan;
|
||||||
video.play();
|
|
||||||
const code = await qr.decodeFromVideo(video);
|
stop.onclick = function () {
|
||||||
console.log('code', code);
|
qr.stop();
|
||||||
result.innerText = 'Result: ' + code.data;
|
video.pause();
|
||||||
}
|
};
|
||||||
|
|
||||||
|
async function startScan() {
|
||||||
|
video.play();
|
||||||
|
const code = await qr.decodeFromVideo(video);
|
||||||
|
console.log('code', code);
|
||||||
|
result.innerText = 'Result: ' + code.data;
|
||||||
}
|
}
|
||||||
main();
|
}
|
||||||
</script>
|
main();
|
||||||
</body>
|
</script>
|
||||||
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,24 +0,0 @@
|
|||||||
{
|
|
||||||
"compilerOptions": {
|
|
||||||
"rootDir": "src",
|
|
||||||
"outDir": "dist",
|
|
||||||
"baseUrl": ".",
|
|
||||||
"downlevelIteration": true,
|
|
||||||
"emitDecoratorMetadata": true,
|
|
||||||
"esModuleInterop": true,
|
|
||||||
"experimentalDecorators": true,
|
|
||||||
"preserveConstEnums": true,
|
|
||||||
"importHelpers": false,
|
|
||||||
"target": "es5",
|
|
||||||
"module": "commonjs",
|
|
||||||
"lib": ["es5", "es6", "dom"],
|
|
||||||
"moduleResolution": "node",
|
|
||||||
"sourceMap": false,
|
|
||||||
"paths": {
|
|
||||||
"*": ["typings/*", "includes/*"]
|
|
||||||
},
|
|
||||||
"resolveJsonModule": true,
|
|
||||||
"noUnusedLocals": true,
|
|
||||||
"strict": true
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue