<granite-qrcode-decoder>
A custom element to decode a QR Code from an image, using a modified version of Lazersoft's jsqrcode library, to allow jsqrcode
to deal with ShadowDOM
Built on lit-element following the open-wc recommendation.
The old Polymer 2.x-1.x version is available on the
polymer-hybrid
branch.
Installation
npm i granite-qrcode-decoder
Usage
The element can decode several sources of images:
- A dataURL, by using the
dataUrl
property - An
app-media-image-capture
, by injecting it to theblob
property - A canvas, by calling the
decodeCanvas
method passing the canvas as parameter
Linting with ESLint, Prettier, and Types
To scan the project for linting errors, run
npm run lint
You can lint with ESLint and Prettier individually as well
npm run lint:eslint
npm run lint:prettier
To automatically fix many linting errors, run
npm run format
You can format using ESLint and Prettier individually as well
npm run format:eslint
npm run format:prettier
Testing with Karma
To run the suite of karma tests, run
npm run test
To run the tests in watch mode (for TDD, for example), run
npm run test:watch
Demoing with Storybook
To run a local instance of Storybook for your component, run
npm run storybook
To build a production version of Storybook, run
npm run storybook:build
Tooling configs
For most of the tools, the configuration is in the package.json
to reduce the amount of files in your project.
If you customize the configuration a lot, you can consider moving them to individual files. \
es-dev-server
Local Demo with npm start
To run a local development server that serves the basic demo located in demo/index.html
Contributing
- Fork it!
- Create your feature branch:
git checkout -b my-new-feature
- Commit your changes:
git commit -m 'Add some feature'
- Push to the branch:
git push origin my-new-feature
- Submit a pull request :D