Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrejnemec/custom-qr-code
Updated version of qr-code-styling library
https://github.com/andrejnemec/custom-qr-code
custom-qr-code qr-code-generator qrcode qrcode-react react react-qr-code-generator
Last synced: about 2 months ago
JSON representation
Updated version of qr-code-styling library
- Host: GitHub
- URL: https://github.com/andrejnemec/custom-qr-code
- Owner: AndrejNemec
- License: mit
- Created: 2024-05-16T16:12:05.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2024-05-17T13:32:07.000Z (8 months ago)
- Last Synced: 2024-11-09T03:48:53.416Z (2 months ago)
- Topics: custom-qr-code, qr-code-generator, qrcode, qrcode-react, react, react-qr-code-generator
- Language: TypeScript
- Homepage:
- Size: 529 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Custom QR Code
[![Version](https://img.shields.io/npm/v/custom-qr-code.svg)](https://www.npmjs.org/package/custom-qr-code)
JavaScript library for generating QR codes with a logo and styling.
This is a fork of the currently unmaintained [repository by kozakdenys](https://github.com/kozakdenys/qr-code-styling) & [repository by KillianB](https://github.com/KilianB/styled-qr-code) fixing multiple issues:
- [#49](https://github.com/kozakdenys/qr-code-styling/issues/105) [#105 QR code is not valid by some scanners](https://github.com/kozakdenys/qr-code-styling/issues/105)
- outdated dependencies
- release for es2017
- migrated from webpack to vite
- added support for react (`import { CustomQRCode } from 'custom-qr-code/react'`)Try the old version here https://qr-code-styling.com to get a feel
### Examples
### Installation
**NPM:**
```
npm install custom-qr-code
```**PNPM:**
```
pnpm install custom-qr-code
```**YARN:**
```
yarn add custom-qr-code
```### Usage
**React**
```tsx
import { CustomQRCode } from "custom-qr-code/react";export const App = () => {
return (
);
};
```**Classic:**
```HTML
QR Code Styling
import { CustomQRCode } from 'https://esm.sh/custom-qr-code'
const qrCode = new CustomQRCode({
width: 300,
height: 300,
type: "svg",
data: "https://www.facebook.com/",
image: "https://upload.wikimedia.org/wikipedia/commons/5/51/Facebook_f_logo_%282019%29.svg",
dotsOptions: {
color: "#4267b2",
type: "rounded"
},
backgroundOptions: {
color: "#e9ebee",
},
imageOptions: {
crossOrigin: "anonymous",
margin: 20
}
});
qrCode.append(document.getElementById("canvas"));
qrCode.download({ name: "qr", extension: "svg" });
```
### API Documentation
#### CustomQRCode instance
`new CustomQRCode(options) => CustomQRCode`
| Param | Type | Description |
| ------- | ------ | ----------- |
| options | object | Init object |`options` structure
| Property | Type | Default Value | Description |
| ----------------------- | ------------------------- | ------------- | --------------------------------------------------------------------------------------------- |
| width | number | `300` | Size of canvas |
| height | number | `300` | Size of canvas |
| type | string (`'canvas' 'svg'`) | `canvas` | The type of the element that will be rendered |
| data | string | | The date will be encoded to the QR code |
| image | string | | The image will be copied to the center of the QR code |
| margin | number | `0` | Margin around canvas |
| qrOptions | object | | Options will be passed to `qrcode-generator` lib |
| imageOptions | object | | Specific image options, details see below |
| dotsOptions | object | | Dots styling options |
| cornersSquareOptions | object | | Square in the corners styling options |
| cornersDotOptionsHelper | object | | Dots in the corners styling options |
| backgroundOptions | object | | QR background styling options |
| useLegacyDotRotation | boolean | false | Use the mirrored qr creation strategy of the original library. (Some scanners might not work) |`options.qrOptions` structure
| Property | Type | Default Value |
| -------------------- | -------------------------------------------------- | ------------- |
| typeNumber | number (`0 - 40`) | `0` |
| mode | string (`'Numeric' 'Alphanumeric' 'Byte' 'Kanji'`) |
| errorCorrectionLevel | string (`'L' 'M' 'Q' 'H'`) | `'Q'` |`options.imageOptions` structure
| Property | Type | Default Value | Description |
| ------------------ | --------------------------------------- | ------------- | ------------------------------------------------------------------------------ |
| hideBackgroundDots | boolean | `true` | Hide all dots covered by the image |
| imageSize | number | `0.4` | Coefficient of the image size. Not recommended to use ove 0.5. Lower is better |
| margin | number | `0` | Margin of the image in px |
| crossOrigin | string(`'anonymous' 'use-credentials'`) | `anonymous` | |`options.dotsOptions` structure
| Property | Type | Default Value | Description |
| -------- | ------------------------------------------------------------------------------ | ------------- | ------------------- |
| color | string | `'#000'` | Color of QR dots |
| gradient | object | | Gradient of QR dots |
| type | string (`'rounded' 'dots' 'classy' 'classy-rounded' 'square' 'extra-rounded'`) | `'square'` | Style of QR dots |`options.backgroundOptions` structure
| Property | Type | Default Value |
| -------- | ------ | ------------- |
| color | string | `'#fff'` |
| gradient | object |`options.cornersSquareOptions` structure
| Property | Type | Default Value | Description |
| -------- | ----------------------------------------- | ------------- | -------------------------- |
| color | string | | Color of Corners Square |
| gradient | object | | Gradient of Corners Square |
| type | string (`'dot' 'square' 'extra-rounded'`) | | Style of Corners Square |`options.cornersDotOptions` structure
| Property | Type | Default Value | Description |
| -------- | ------------------------- | ------------- | ----------------------- |
| color | string | | Color of Corners Dot |
| gradient | object | | Gradient of Corners Dot |
| type | string (`'dot' 'square'`) | | Style of Corners Dot |Gradient structure
`options.dotsOptions.gradient`
`options.backgroundOptions.gradient`
`options.cornersSquareOptions.gradient`
`options.cornersDotOptions.gradient`
| Property | Type | Default Value | Description |
| ---------- | ---------------------------- | ------------- | -------------------------------------------------------------------------------------- |
| type | string (`'linear' 'radial'`) | "linear" | Type of gradient spread |
| rotation | number | 0 | Rotation of gradient in radians (Math.PI === 180 degrees) |
| colorStops | array of objects | | Gradient colors. Example `[{ offset: 0, color: 'blue' }, { offset: 1, color: 'red' }]` |Gradient colorStops structure
`options.dotsOptions.gradient.colorStops[]`
`options.backgroundOptions.gradient.colorStops[]`
`options.cornersSquareOptions.gradient.colorStops[]`
`options.cornersDotOptions.gradient.colorStops[]`
| Property | Type | Default Value | Description |
| -------- | ---------------- | ------------- | ----------------------------------- |
| offset | number (`0 - 1`) | | Position of color in gradient range |
| color | string | | Color of stop in gradient range |#### CustomQRCode methods
`CustomQRCode.append(container) => void`
| Param | Type | Description |
| --------- | ----------- | -------------------------------------------------------- |
| container | DOM element | This container will be used for appending of the QR code |`CustomQRCode.getRawData(extension) => Promise`
| Param | Type | Default Value | Description |
| --------- | ------------------------------------ | ------------- | ----------- |
| extension | string (`'png' 'jpeg' 'webp' 'svg'`) | `'png'` | Blob type |`CustomQRCode.update(options) => void`
| Param | Type | Description |
| ------- | ------ | -------------------------------------- |
| options | object | The same options as for initialization |`CustomQRCode.download(downloadOptions, quality) => Promise`
| Param | Type | Description |
| --------------- | ------ | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| downloadOptions | object | Options with extension and name of file (not required) |
| quality | number | A Number between 0 and 1 indicating the image quality to be used when creating images using file formats that support lossy compression (such as image/jpeg or image/webp). A user agent will use its default quality value if this option is not specified, or if the number is outside the allowed range. |`downloadOptions` structure
| Property | Type | Default Value | Description |
| --------- | ------------------------------------ | ------------- | --------------------------- |
| name | string | `'qr'` | Name of the downloaded file |
| extension | string (`'png' 'jpeg' 'webp' 'svg'`) | `'png'` | File extension |`CustomQRCode.toDataUrl(extension, quality) => Promise`
| Param | Type | Default Value | Description |
| --------- | ------------------------------ | ------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| extension | string (`'png' 'jpeg' 'webp')` | 'png' | Blob type |
| quality | number | undefined | [A Number between 0 and 1 indicating the image quality to be used when creating images using file formats that support lossy compression (such as image/jpeg or image/webp). A user agent will use its default quality value if this option is not specified, or if the number is outside the allowed range. |### License
[MIT License](https://github.com/AndrejNemec/custom-qr-code/raw/main/LICENSE). Copyright (c) 2024 Andrej Nemec