@granite-elements/granite-qrcode-decoder v4.0.0
\
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 following the open-wc recommendation.
The old Polymer 2.x-1.x version is available on the
polymer-hybridbranch.
Installation
npm i granite-qrcode-decoderUsage
The element can decode several sources of images:
- A dataURL, by using the
dataUrlproperty - An
app-media-image-capture, by injecting it to theblobproperty - A canvas, by calling the
decodeCanvasmethod passing the canvas as parameter
<script type="module">
import 'granite-qrcode-decoder/index.js';
</script>
<granite-qrcode-decoder
@qrcode-decoded="${method_listening_for_data}"
data-url=""
debug></granite-qrcode-decoder>Linting with ESLint, Prettier, and Types
To scan the project for linting errors, run
npm run lintYou can lint with ESLint and Prettier individually as well
npm run lint:eslintnpm run lint:prettierTo automatically fix many linting errors, run
npm run formatYou can format using ESLint and Prettier individually as well
npm run format:eslintnpm run format:prettierTesting with Karma
To run the suite of karma tests, run
npm run testTo run the tests in watch mode (for TDD, for example), run
npm run test:watchDemoing with Storybook
To run a local instance of Storybook for your component, run
npm run storybookTo build a production version of Storybook, run
npm run storybook:buildTooling 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. \
Local Demo with @web/dev-server
npm startTo 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