Skip to content

xuannghia/qrto

Repository files navigation

QRto - Styled QR Code Generator

Installation

npm install qrto

toSVG

NodeJS/Express

const express = require('express');
const { toSVG } = require('qrto');

const app = express();

app.get('/qr.svg', (req, res) => {
  const svg = toSVG("https://github.com/xuannghia/qrto", {
    style: 'circle',
    marker: {
      style: {
        outer: 'round',
        inner: 'circle',
      }
    },
    // Because of the origin policy
    // the logo URL should be a base64 string or hosted on the same domain as the QR code.
    logo: {
      url: '',
    },
    foregroundColor: {
      type: 'linear',
      colors: ['#5271C1', '#0F1E43'],
    },
  })
  res.set('Content-Type', 'image/svg+xml');
  res.send(svg);
});

app.listen(8000, () => {
  console.log('Server is running on port 8000');
});

ReactJS

import React from 'react';

import { toSVG } from 'qrto';

const App = () => {
  const svgString = toSVG("https://github.com/xuannghia/qrto", {
    style: 'circle',
    marker: {
      style: {
        outer: 'round',
        inner: 'circle',
      }
    },
    // Because of the origin policy
    // the logo URL should be a base64 string or hosted on the same domain as the QR code.
    logo: {
      url: '',
    },
    foregroundColor: {
      type: 'linear',
      colors: ['#5271C1', '#0F1E43'],
    },
  })

  // Because toSVG just return a raw string
  // So we need to use `dangerouslySetInnerHTML` to render it as SVG Element
  return <div dangerouslySetInnerHTML={{ __html: svgString }} />
}

toCanvas

Coming soon...

About

Generate styled QRCode in any JS runtime

Resources

Stars

Watchers

Forks