Socket
Socket
Sign inDemoInstall

qrcode.vue

Package Overview
Dependencies
Maintainers
1
Versions
33
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

qrcode.vue - npm Package Compare versions

Comparing version 1.6.3 to 1.7.0

6

CHANGELOG.md

@@ -0,1 +1,7 @@

## [1.7.0]
### Feature
- Support generate Qrcode as svg.
## [1.6.3] - 2019-09-16

@@ -2,0 +8,0 @@

124

dist/qrcode.vue.esm.js
/*!
* qrcode.vue v1.6.3
* A Vue component for QRCode.
* qrcode.vue v1.7.0
* A Vue component to generate QRCode.
* © 2017-2019 @scopewu(https://github.com/scopewu)

@@ -926,2 +926,43 @@ * MIT License.

return utf8Str;
}
function generatePath(modules) {
var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
var ops = [];
modules.forEach(function (row, y) {
var start = null;
row.forEach(function (cell, x) {
if (!cell && start !== null) {
// M0 0h7v1H0z injects the space with the move and drops the comma,
// saving a char per operation
ops.push("M".concat(start + margin, " ").concat(y + margin, "h").concat(x - start, "v1H").concat(start + margin, "z"));
start = null;
return;
} // end of row, clean up or skip
if (x === row.length - 1) {
if (!cell) {
// We would have closed the op above already so this can only mean
// 2+ light modules in a row.
return;
}
if (start === null) {
// Just a single dark module.
ops.push("M".concat(x + margin, ",").concat(y + margin, " h1v1H").concat(x + margin, "z"));
} else {
// Otherwise finish the current line.
ops.push("M".concat(start + margin, ",").concat(y + margin, " h").concat(x + 1 - start, "v1H").concat(start + margin, "z"));
}
return;
}
if (cell && start === null) {
start = x;
}
});
});
return ops.join('');
} // @vue/component

@@ -962,4 +1003,18 @@

default: '#000'
},
renderAs: {
type: String,
required: false,
default: 'canvas',
validator: function validator(as) {
return ['canvas', 'svg'].indexOf(as) > -1;
}
}
},
data: function data() {
return {
numCells: 0,
fgPath: ''
};
},
updated: function updated() {

@@ -977,3 +1032,4 @@ this.render();

background = this.background,
foreground = this.foreground;
foreground = this.foreground,
renderAs = this.renderAs;

@@ -987,4 +1043,2 @@ var _size = size >>> 0; // size to number

qrCode.make();
var canvas = this.$refs['qrcode-vue'];
var ctx = canvas.getContext('2d');
var cells = qrCode.modules;

@@ -994,12 +1048,26 @@ var tileW = _size / cells.length;

var scale = window.devicePixelRatio || 1;
canvas.height = canvas.width = _size * scale;
ctx.scale(scale, scale);
cells.forEach(function (row, rdx) {
row.forEach(function (cell, cdx) {
ctx.fillStyle = cell ? foreground : background;
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW);
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH);
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h);
if (renderAs === 'svg') {
this.numCells = cells.length; // Drawing strategy: instead of a rect per module, we're going to create a
// single path for the dark modules and layer that on top of a light rect,
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's
// way faster than DOM ops.
// For level 1, 441 nodes -> 2
// For level 40, 31329 -> 2
this.fgPath = generatePath(cells);
} else {
var canvas = this.$refs['qrcode-vue'];
var ctx = canvas.getContext('2d');
canvas.height = canvas.width = _size * scale;
ctx.scale(scale, scale);
cells.forEach(function (row, rdx) {
row.forEach(function (cell, cdx) {
ctx.fillStyle = cell ? foreground : background;
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW);
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH);
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h);
});
});
});
}
}

@@ -1013,3 +1081,6 @@ },

foreground = this.foreground,
size = this.size;
size = this.size,
renderAs = this.renderAs,
numCells = this.numCells,
fgPath = this.fgPath;
return createElement('div', {

@@ -1023,5 +1094,26 @@ class: this.class || className,

}
}, [createElement('canvas', {
}, [renderAs === 'svg' ? createElement('svg', {
attrs: {
height: size,
width: size,
shapeRendering: 'crispEdges',
viewBox: "0 0 ".concat(numCells, " ").concat(numCells)
},
style: {
width: size + 'px',
height: size + 'px'
}
}, [createElement('path', {
attrs: {
fill: background,
d: "M0,0 h".concat(numCells, "v").concat(numCells, "H0z")
}
}), createElement('path', {
attrs: {
fill: foreground,
d: fgPath
}
})]) : createElement('canvas', {
attrs: {
height: size,
width: size

@@ -1028,0 +1120,0 @@ },

/*!
* qrcode.vue v1.6.3
* A Vue component for QRCode.
* qrcode.vue v1.7.0
* A Vue component to generate QRCode.
* © 2017-2019 @scopewu(https://github.com/scopewu)

@@ -932,2 +932,43 @@ * MIT License.

return utf8Str;
}
function generatePath(modules) {
var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
var ops = [];
modules.forEach(function (row, y) {
var start = null;
row.forEach(function (cell, x) {
if (!cell && start !== null) {
// M0 0h7v1H0z injects the space with the move and drops the comma,
// saving a char per operation
ops.push("M".concat(start + margin, " ").concat(y + margin, "h").concat(x - start, "v1H").concat(start + margin, "z"));
start = null;
return;
} // end of row, clean up or skip
if (x === row.length - 1) {
if (!cell) {
// We would have closed the op above already so this can only mean
// 2+ light modules in a row.
return;
}
if (start === null) {
// Just a single dark module.
ops.push("M".concat(x + margin, ",").concat(y + margin, " h1v1H").concat(x + margin, "z"));
} else {
// Otherwise finish the current line.
ops.push("M".concat(start + margin, ",").concat(y + margin, " h").concat(x + 1 - start, "v1H").concat(start + margin, "z"));
}
return;
}
if (cell && start === null) {
start = x;
}
});
});
return ops.join('');
} // @vue/component

@@ -968,4 +1009,18 @@

default: '#000'
},
renderAs: {
type: String,
required: false,
default: 'canvas',
validator: function validator(as) {
return ['canvas', 'svg'].indexOf(as) > -1;
}
}
},
data: function data() {
return {
numCells: 0,
fgPath: ''
};
},
updated: function updated() {

@@ -983,3 +1038,4 @@ this.render();

background = this.background,
foreground = this.foreground;
foreground = this.foreground,
renderAs = this.renderAs;

@@ -993,4 +1049,2 @@ var _size = size >>> 0; // size to number

qrCode.make();
var canvas = this.$refs['qrcode-vue'];
var ctx = canvas.getContext('2d');
var cells = qrCode.modules;

@@ -1000,12 +1054,26 @@ var tileW = _size / cells.length;

var scale = window.devicePixelRatio || 1;
canvas.height = canvas.width = _size * scale;
ctx.scale(scale, scale);
cells.forEach(function (row, rdx) {
row.forEach(function (cell, cdx) {
ctx.fillStyle = cell ? foreground : background;
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW);
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH);
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h);
if (renderAs === 'svg') {
this.numCells = cells.length; // Drawing strategy: instead of a rect per module, we're going to create a
// single path for the dark modules and layer that on top of a light rect,
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's
// way faster than DOM ops.
// For level 1, 441 nodes -> 2
// For level 40, 31329 -> 2
this.fgPath = generatePath(cells);
} else {
var canvas = this.$refs['qrcode-vue'];
var ctx = canvas.getContext('2d');
canvas.height = canvas.width = _size * scale;
ctx.scale(scale, scale);
cells.forEach(function (row, rdx) {
row.forEach(function (cell, cdx) {
ctx.fillStyle = cell ? foreground : background;
var w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW);
var h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH);
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h);
});
});
});
}
}

@@ -1019,3 +1087,6 @@ },

foreground = this.foreground,
size = this.size;
size = this.size,
renderAs = this.renderAs,
numCells = this.numCells,
fgPath = this.fgPath;
return createElement('div', {

@@ -1029,5 +1100,26 @@ class: this.class || className,

}
}, [createElement('canvas', {
}, [renderAs === 'svg' ? createElement('svg', {
attrs: {
height: size,
width: size,
shapeRendering: 'crispEdges',
viewBox: "0 0 ".concat(numCells, " ").concat(numCells)
},
style: {
width: size + 'px',
height: size + 'px'
}
}, [createElement('path', {
attrs: {
fill: background,
d: "M0,0 h".concat(numCells, "v").concat(numCells, "H0z")
}
}), createElement('path', {
attrs: {
fill: foreground,
d: fgPath
}
})]) : createElement('canvas', {
attrs: {
height: size,
width: size

@@ -1034,0 +1126,0 @@ },

6

dist/qrcode.vue.min.js
/*!
* qrcode.vue v1.6.3
* A Vue component for QRCode.
* qrcode.vue v1.7.0
* A Vue component to generate QRCode.
* © 2017-2019 @scopewu(https://github.com/scopewu)
* MIT License.
*/
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).QrcodeVue=e()}(this,function(){"use strict";var r=1,o=2,n=4,i=8;function t(t){this.mode=n,this.data=t}t.prototype={getLength:function(t){return this.data.length},write:function(t){for(var e=0;e<this.data.length;e++)t.put(this.data.charCodeAt(e),8)}};var a=t,f={L:1,M:0,Q:3,H:2};function l(t,e){this.totalCount=t,this.dataCount=e}l.RS_BLOCK_TABLE=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12],[5,122,98,1,123,99],[7,73,45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]],l.getRSBlocks=function(t,e){var r=l.getRsBlockTable(t,e);if(null==r)throw Error("bad rs block @ typeNumber:"+t+"/errorCorrectLevel:"+e);for(var o=r.length/3,n=[],i=0;i<o;i++)for(var a=r[3*i+0],s=r[3*i+1],u=r[3*i+2],h=0;h<a;h++)n.push(new l(s,u));return n},l.getRsBlockTable=function(t,e){switch(e){case f.L:return l.RS_BLOCK_TABLE[4*(t-1)+0];case f.M:return l.RS_BLOCK_TABLE[4*(t-1)+1];case f.Q:return l.RS_BLOCK_TABLE[4*(t-1)+2];case f.H:return l.RS_BLOCK_TABLE[4*(t-1)+3];default:return}};var u=l;function e(){this.buffer=[],this.length=0}e.prototype={get:function(t){return 1==(this.buffer[Math.floor(t/8)]>>>7-t%8&1)},put:function(t,e){for(var r=0;r<e;r++)this.putBit(1==(t>>>e-r-1&1))},getLengthInBits:function(){return this.length},putBit:function(t){var e=Math.floor(this.length/8);e<this.buffer.length||this.buffer.push(0),t&&(this.buffer[e]|=128>>>this.length%8),this.length++}};for(var h=e,s={glog:function(t){if(t<1)throw Error("glog("+t+")");return s.LOG_TABLE[t]},gexp:function(t){for(;t<0;)t+=255;for(;256<=t;)t-=255;return s.EXP_TABLE[t]},EXP_TABLE:Array(256),LOG_TABLE:Array(256)},g=0;g<8;g++)s.EXP_TABLE[g]=1<<g;for(g=8;g<256;g++)s.EXP_TABLE[g]=s.EXP_TABLE[g-4]^s.EXP_TABLE[g-5]^s.EXP_TABLE[g-6]^s.EXP_TABLE[g-8];for(g=0;g<255;g++)s.LOG_TABLE[s.EXP_TABLE[g]]=g;var d=s;function c(t,e){if(null==t.length)throw Error(t.length+"/"+e);for(var r=0;r<t.length&&0==t[r];)r++;this.num=Array(t.length-r+e);for(var o=0;o<t.length-r;o++)this.num[o]=t[o+r]}c.prototype={get:function(t){return this.num[t]},getLength:function(){return this.num.length},multiply:function(t){for(var e=Array(this.getLength()+t.getLength()-1),r=0;r<this.getLength();r++)for(var o=0;o<t.getLength();o++)e[r+o]^=d.gexp(d.glog(this.get(r))+d.glog(t.get(o)));return new c(e,0)},mod:function(t){if(this.getLength()-t.getLength()<0)return this;for(var e=d.glog(this.get(0))-d.glog(t.get(0)),r=Array(this.getLength()),o=0;o<this.getLength();o++)r[o]=this.get(o);for(o=0;o<t.getLength();o++)r[o]^=d.gexp(d.glog(t.get(o))+e);return new c(r,0).mod(t)}};var p=c,m=0,v=1,C=2,L=3,B=4,y=5,P=6,k=7,E={PATTERN_POSITION_TABLE:[[],[6,18],[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],G15:1335,G18:7973,G15_MASK:21522,getBCHTypeInfo:function(t){for(var e=t<<10;0<=E.getBCHDigit(e)-E.getBCHDigit(E.G15);)e^=E.G15<<E.getBCHDigit(e)-E.getBCHDigit(E.G15);return(t<<10|e)^E.G15_MASK},getBCHTypeNumber:function(t){for(var e=t<<12;0<=E.getBCHDigit(e)-E.getBCHDigit(E.G18);)e^=E.G18<<E.getBCHDigit(e)-E.getBCHDigit(E.G18);return t<<12|e},getBCHDigit:function(t){for(var e=0;0!=t;)e++,t>>>=1;return e},getPatternPosition:function(t){return E.PATTERN_POSITION_TABLE[t-1]},getMask:function(t,e,r){switch(t){case m:return(e+r)%2==0;case v:return e%2==0;case C:return r%3==0;case L:return(e+r)%3==0;case B:return(Math.floor(e/2)+Math.floor(r/3))%2==0;case y:return e*r%2+e*r%3==0;case P:return(e*r%2+e*r%3)%2==0;case k:return(e*r%3+(e+r)%2)%2==0;default:throw Error("bad maskPattern:"+t)}},getErrorCorrectPolynomial:function(t){for(var e=new p([1],0),r=0;r<t;r++)e=e.multiply(new p([1,d.gexp(r)],0));return e},getLengthInBits:function(t,e){if(1<=e&&e<10)switch(t){case r:return 10;case o:return 9;case n:case i:return 8;default:throw Error("mode:"+t)}else if(e<27)switch(t){case r:return 12;case o:return 11;case n:return 16;case i:return 10;default:throw Error("mode:"+t)}else{if(41<=e)throw Error("type:"+e);switch(t){case r:return 14;case o:return 13;case n:return 16;case i:return 12;default:throw Error("mode:"+t)}}},getLostPoint:function(t){for(var e=t.getModuleCount(),r=0,o=0;o<e;o++)for(var n=0;n<e;n++){for(var i=0,a=t.isDark(o,n),s=-1;s<=1;s++)if(0<=o+s&&o+s<e)for(var u=-1;u<=1;u++)0<=n+u&&n+u<e&&(0==s&&0==u||a==t.isDark(o+s,n+u)&&i++);5<i&&(r+=3+i-5)}for(o=0;o<e-1;o++)for(n=0;n<e-1;n++){var h=0;t.isDark(o,n)&&h++,t.isDark(o+1,n)&&h++,t.isDark(o,n+1)&&h++,t.isDark(o+1,n+1)&&h++,0!=h&&4!=h||(r+=3)}for(o=0;o<e;o++)for(n=0;n<e-6;n++)t.isDark(o,n)&&!t.isDark(o,n+1)&&t.isDark(o,n+2)&&t.isDark(o,n+3)&&t.isDark(o,n+4)&&!t.isDark(o,n+5)&&t.isDark(o,n+6)&&(r+=40);for(n=0;n<e;n++)for(o=0;o<e-6;o++)t.isDark(o,n)&&!t.isDark(o+1,n)&&t.isDark(o+2,n)&&t.isDark(o+3,n)&&t.isDark(o+4,n)&&!t.isDark(o+5,n)&&t.isDark(o+6,n)&&(r+=40);var l=0;for(n=0;n<e;n++)for(o=0;o<e;o++)t.isDark(o,n)&&l++;return r+=10*(Math.abs(100*l/e/e-50)/5)}},A=E;function D(t,e){this.typeNumber=t,this.errorCorrectLevel=e,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}var T=D.prototype;T.addData=function(t){var e=new a(t);this.dataList.push(e),this.dataCache=null},T.isDark=function(t,e){if(t<0||this.moduleCount<=t||e<0||this.moduleCount<=e)throw Error(t+","+e);return this.modules[t][e]},T.getModuleCount=function(){return this.moduleCount},T.make=function(){if(this.typeNumber<1){var t=1;for(t=1;t<40;t++){for(var e=u.getRSBlocks(t,this.errorCorrectLevel),r=new h,o=0,n=0;n<e.length;n++)o+=e[n].dataCount;for(n=0;n<this.dataList.length;n++){var i=this.dataList[n];r.put(i.mode,4),r.put(i.getLength(),A.getLengthInBits(i.mode,t)),i.write(r)}if(r.getLengthInBits()<=8*o)break}this.typeNumber=t}this.makeImpl(!1,this.getBestMaskPattern())},T.makeImpl=function(t,e){this.moduleCount=4*this.typeNumber+17,this.modules=Array(this.moduleCount);for(var r=0;r<this.moduleCount;r++){this.modules[r]=Array(this.moduleCount);for(var o=0;o<this.moduleCount;o++)this.modules[r][o]=null}this.setupPositionProbePattern(0,0),this.setupPositionProbePattern(this.moduleCount-7,0),this.setupPositionProbePattern(0,this.moduleCount-7),this.setupPositionAdjustPattern(),this.setupTimingPattern(),this.setupTypeInfo(t,e),this.typeNumber<7||this.setupTypeNumber(t),null==this.dataCache&&(this.dataCache=D.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,e)},T.setupPositionProbePattern=function(t,e){for(var r=-1;r<=7;r++)if(-1<t+r&&t+r<this.moduleCount)for(var o=-1;o<=7;o++)-1<e+o&&e+o<this.moduleCount&&(this.modules[t+r][e+o]=!((r<0||6<r||0!=o&&6!=o)&&(o<0||6<o||0!=r&&6!=r)&&(r<2||4<r||o<2||4<o)))},T.getBestMaskPattern=function(){for(var t=0,e=0,r=0;r<8;r++){this.makeImpl(!0,r);var o=A.getLostPoint(this);0!=r&&t<=o||(t=o,e=r)}return e},T.createMovieClip=function(t,e,r){var o=t.createEmptyMovieClip(e,r);this.make();for(var n=0;n<this.modules.length;n++)for(var i=1*n,a=0;a<this.modules[n].length;a++){var s=1*a;this.modules[n][a]&&(o.beginFill(0,100),o.moveTo(s,i),o.lineTo(1+s,i),o.lineTo(1+s,1+i),o.lineTo(s,1+i),o.endFill())}return o},T.setupTimingPattern=function(){for(var t=8;t<this.moduleCount-8;t++)null==this.modules[t][6]&&(this.modules[t][6]=t%2==0);for(var e=8;e<this.moduleCount-8;e++)null==this.modules[6][e]&&(this.modules[6][e]=e%2==0)},T.setupPositionAdjustPattern=function(){for(var t=A.getPatternPosition(this.typeNumber),e=0;e<t.length;e++)for(var r=0;r<t.length;r++){var o=t[e],n=t[r];if(null==this.modules[o][n])for(var i=-2;i<=2;i++)for(var a=-2;a<=2;a++)this.modules[o+i][n+a]=-2==i||2==i||-2==a||2==a||0==i&&0==a}},T.setupTypeNumber=function(t){for(var e=A.getBCHTypeNumber(this.typeNumber),r=0;r<18;r++){var o=!t&&1==(e>>r&1);this.modules[Math.floor(r/3)][r%3+this.moduleCount-8-3]=o}for(r=0;r<18;r++){o=!t&&1==(e>>r&1);this.modules[r%3+this.moduleCount-8-3][Math.floor(r/3)]=o}},T.setupTypeInfo=function(t,e){for(var r=A.getBCHTypeInfo(this.errorCorrectLevel<<3|e),o=0;o<15;o++){var n=!t&&1==(r>>o&1);o<6?this.modules[o][8]=n:o<8?this.modules[o+1][8]=n:this.modules[this.moduleCount-15+o][8]=n}for(o=0;o<15;o++){n=!t&&1==(r>>o&1);o<8?this.modules[8][this.moduleCount-o-1]=n:o<9?this.modules[8][15-o-1+1]=n:this.modules[8][15-o-1]=n}this.modules[this.moduleCount-8][8]=!t},T.mapData=function(t,e){for(var r=-1,o=this.moduleCount-1,n=7,i=0,a=this.moduleCount-1;0<a;a-=2)for(6==a&&a--;;){for(var s=0;s<2;s++)if(null==this.modules[o][a-s]){var u=!1;i<t.length&&(u=1==(t[i]>>>n&1)),A.getMask(e,o,a-s)&&(u=!u),this.modules[o][a-s]=u,-1==--n&&(i++,n=7)}if((o+=r)<0||this.moduleCount<=o){o-=r,r=-r;break}}},D.PAD0=236,D.PAD1=17,D.createData=function(t,e,r){for(var o=u.getRSBlocks(t,e),n=new h,i=0;i<r.length;i++){var a=r[i];n.put(a.mode,4),n.put(a.getLength(),A.getLengthInBits(a.mode,t)),a.write(n)}var s=0;for(i=0;i<o.length;i++)s+=o[i].dataCount;if(n.getLengthInBits()>8*s)throw Error("code length overflow. ("+n.getLengthInBits()+">"+8*s+")");for(n.getLengthInBits()+4>8*s||n.put(0,4);n.getLengthInBits()%8!=0;)n.putBit(!1);for(;n.getLengthInBits()<8*s&&(n.put(D.PAD0,8),n.getLengthInBits()<8*s);)n.put(D.PAD1,8);return D.createBytes(n,o)},D.createBytes=function(t,e){for(var r=0,o=0,n=0,i=Array(e.length),a=Array(e.length),s=0;s<e.length;s++){var u=e[s].dataCount,h=e[s].totalCount-u;o=Math.max(o,u),n=Math.max(n,h),i[s]=Array(u);for(var l=0;l<i[s].length;l++)i[s][l]=255&t.buffer[l+r];r+=u;var f=A.getErrorCorrectPolynomial(h),g=new p(i[s],f.getLength()-1).mod(f);a[s]=Array(f.getLength()-1);for(l=0;l<a[s].length;l++){var d=l+g.getLength()-a[s].length;a[s][l]=d<0?0:g.get(d)}}var c=0;for(l=0;l<e.length;l++)c+=e[l].totalCount;var m=Array(c),v=0;for(l=0;l<o;l++)for(s=0;s<e.length;s++)l<i[s].length&&(m[v++]=i[s][l]);for(l=0;l<n;l++)for(s=0;s<e.length;s++)l<a[s].length&&(m[v++]=a[s][l]);return m};var b=D;return{props:{value:{type:String,required:!0,default:""},className:{type:String,default:""},size:{type:[Number,String],default:100,validator:function(t){return!0!==isNaN(+t)}},level:{type:String,default:"L",validator:function(t){return!!~["L","Q","M","H"].indexOf(t)}},background:{type:String,default:"#fff"},foreground:{type:String,default:"#000"}},updated:function(){this.render()},mounted:function(){this.render()},methods:{render:function(){var t=this.value,i=this.background,a=this.foreground,e=this.size>>>0,r=new b(-1,f[this.level]);r.addData(function(t){for(var e="",r=0;r<t.length;r++){var o=t.charCodeAt(r);o<128?e+=String.fromCharCode(o):(o<2048?e+=String.fromCharCode(192|o>>6):(o<55296||57344<=o?e+=String.fromCharCode(224|o>>12):(o=65536+((1023&o)<<10|1023&t.charCodeAt(++r)),e+=String.fromCharCode(240|o>>18),e+=String.fromCharCode(128|o>>12&63)),e+=String.fromCharCode(128|o>>6&63)),e+=String.fromCharCode(128|63&o))}return e}(t)),r.make();var o=this.$refs["qrcode-vue"],s=o.getContext("2d"),n=r.modules,u=e/n.length,h=e/n.length,l=window.devicePixelRatio||1;o.height=o.width=e*l,s.scale(l,l),n.forEach(function(t,n){t.forEach(function(t,e){s.fillStyle=t?a:i;var r=Math.ceil((e+1)*u)-Math.floor(e*u),o=Math.ceil((n+1)*h)-Math.floor(n*h);s.fillRect(Math.round(e*u),Math.round(n*h),r,o)})})}},render:function(t){var e=this.size;return t("div",{class:this.class||this.className,attrs:{value:this.value,level:this.level,background:this.background,foreground:this.foreground}},[t("canvas",{attrs:{height:e,width:e},style:{width:e+"px",height:e+"px"},ref:"qrcode-vue"},[])])}}});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t=t||self).QrcodeVue=e()}(this,function(){"use strict";var r=1,n=2,o=4,i=8;function t(t){this.mode=o,this.data=t}t.prototype={getLength:function(t){return this.data.length},write:function(t){for(var e=0;e<this.data.length;e++)t.put(this.data.charCodeAt(e),8)}};var a=t,g={L:1,M:0,Q:3,H:2};function l(t,e){this.totalCount=t,this.dataCount=e}l.RS_BLOCK_TABLE=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12],[5,122,98,1,123,99],[7,73,45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]],l.getRSBlocks=function(t,e){var r=l.getRsBlockTable(t,e);if(null==r)throw Error("bad rs block @ typeNumber:"+t+"/errorCorrectLevel:"+e);for(var n=r.length/3,o=[],i=0;i<n;i++)for(var a=r[3*i+0],s=r[3*i+1],u=r[3*i+2],h=0;h<a;h++)o.push(new l(s,u));return o},l.getRsBlockTable=function(t,e){switch(e){case g.L:return l.RS_BLOCK_TABLE[4*(t-1)+0];case g.M:return l.RS_BLOCK_TABLE[4*(t-1)+1];case g.Q:return l.RS_BLOCK_TABLE[4*(t-1)+2];case g.H:return l.RS_BLOCK_TABLE[4*(t-1)+3];default:return}};var u=l;function e(){this.buffer=[],this.length=0}e.prototype={get:function(t){return 1==(this.buffer[Math.floor(t/8)]>>>7-t%8&1)},put:function(t,e){for(var r=0;r<e;r++)this.putBit(1==(t>>>e-r-1&1))},getLengthInBits:function(){return this.length},putBit:function(t){var e=Math.floor(this.length/8);e<this.buffer.length||this.buffer.push(0),t&&(this.buffer[e]|=128>>>this.length%8),this.length++}};for(var h=e,s={glog:function(t){if(t<1)throw Error("glog("+t+")");return s.LOG_TABLE[t]},gexp:function(t){for(;t<0;)t+=255;for(;256<=t;)t-=255;return s.EXP_TABLE[t]},EXP_TABLE:Array(256),LOG_TABLE:Array(256)},f=0;f<8;f++)s.EXP_TABLE[f]=1<<f;for(f=8;f<256;f++)s.EXP_TABLE[f]=s.EXP_TABLE[f-4]^s.EXP_TABLE[f-5]^s.EXP_TABLE[f-6]^s.EXP_TABLE[f-8];for(f=0;f<255;f++)s.LOG_TABLE[s.EXP_TABLE[f]]=f;var c=s;function d(t,e){if(null==t.length)throw Error(t.length+"/"+e);for(var r=0;r<t.length&&0==t[r];)r++;this.num=Array(t.length-r+e);for(var n=0;n<t.length-r;n++)this.num[n]=t[n+r]}d.prototype={get:function(t){return this.num[t]},getLength:function(){return this.num.length},multiply:function(t){for(var e=Array(this.getLength()+t.getLength()-1),r=0;r<this.getLength();r++)for(var n=0;n<t.getLength();n++)e[r+n]^=c.gexp(c.glog(this.get(r))+c.glog(t.get(n)));return new d(e,0)},mod:function(t){if(this.getLength()-t.getLength()<0)return this;for(var e=c.glog(this.get(0))-c.glog(t.get(0)),r=Array(this.getLength()),n=0;n<this.getLength();n++)r[n]=this.get(n);for(n=0;n<t.getLength();n++)r[n]^=c.gexp(c.glog(t.get(n))+e);return new d(r,0).mod(t)}};var p=d,m=0,v=1,C=2,L=3,B=4,y=5,P=6,E=7,A={PATTERN_POSITION_TABLE:[[],[6,18],[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],G15:1335,G18:7973,G15_MASK:21522,getBCHTypeInfo:function(t){for(var e=t<<10;0<=A.getBCHDigit(e)-A.getBCHDigit(A.G15);)e^=A.G15<<A.getBCHDigit(e)-A.getBCHDigit(A.G15);return(t<<10|e)^A.G15_MASK},getBCHTypeNumber:function(t){for(var e=t<<12;0<=A.getBCHDigit(e)-A.getBCHDigit(A.G18);)e^=A.G18<<A.getBCHDigit(e)-A.getBCHDigit(A.G18);return t<<12|e},getBCHDigit:function(t){for(var e=0;0!=t;)e++,t>>>=1;return e},getPatternPosition:function(t){return A.PATTERN_POSITION_TABLE[t-1]},getMask:function(t,e,r){switch(t){case m:return(e+r)%2==0;case v:return e%2==0;case C:return r%3==0;case L:return(e+r)%3==0;case B:return(Math.floor(e/2)+Math.floor(r/3))%2==0;case y:return e*r%2+e*r%3==0;case P:return(e*r%2+e*r%3)%2==0;case E:return(e*r%3+(e+r)%2)%2==0;default:throw Error("bad maskPattern:"+t)}},getErrorCorrectPolynomial:function(t){for(var e=new p([1],0),r=0;r<t;r++)e=e.multiply(new p([1,c.gexp(r)],0));return e},getLengthInBits:function(t,e){if(1<=e&&e<10)switch(t){case r:return 10;case n:return 9;case o:case i:return 8;default:throw Error("mode:"+t)}else if(e<27)switch(t){case r:return 12;case n:return 11;case o:return 16;case i:return 10;default:throw Error("mode:"+t)}else{if(41<=e)throw Error("type:"+e);switch(t){case r:return 14;case n:return 13;case o:return 16;case i:return 12;default:throw Error("mode:"+t)}}},getLostPoint:function(t){for(var e=t.getModuleCount(),r=0,n=0;n<e;n++)for(var o=0;o<e;o++){for(var i=0,a=t.isDark(n,o),s=-1;s<=1;s++)if(0<=n+s&&n+s<e)for(var u=-1;u<=1;u++)0<=o+u&&o+u<e&&(0==s&&0==u||a==t.isDark(n+s,o+u)&&i++);5<i&&(r+=3+i-5)}for(n=0;n<e-1;n++)for(o=0;o<e-1;o++){var h=0;t.isDark(n,o)&&h++,t.isDark(n+1,o)&&h++,t.isDark(n,o+1)&&h++,t.isDark(n+1,o+1)&&h++,0!=h&&4!=h||(r+=3)}for(n=0;n<e;n++)for(o=0;o<e-6;o++)t.isDark(n,o)&&!t.isDark(n,o+1)&&t.isDark(n,o+2)&&t.isDark(n,o+3)&&t.isDark(n,o+4)&&!t.isDark(n,o+5)&&t.isDark(n,o+6)&&(r+=40);for(o=0;o<e;o++)for(n=0;n<e-6;n++)t.isDark(n,o)&&!t.isDark(n+1,o)&&t.isDark(n+2,o)&&t.isDark(n+3,o)&&t.isDark(n+4,o)&&!t.isDark(n+5,o)&&t.isDark(n+6,o)&&(r+=40);var l=0;for(o=0;o<e;o++)for(n=0;n<e;n++)t.isDark(n,o)&&l++;return r+=10*(Math.abs(100*l/e/e-50)/5)}},k=A;function D(t,e){this.typeNumber=t,this.errorCorrectLevel=e,this.modules=null,this.moduleCount=0,this.dataCache=null,this.dataList=[]}var T=D.prototype;T.addData=function(t){var e=new a(t);this.dataList.push(e),this.dataCache=null},T.isDark=function(t,e){if(t<0||this.moduleCount<=t||e<0||this.moduleCount<=e)throw Error(t+","+e);return this.modules[t][e]},T.getModuleCount=function(){return this.moduleCount},T.make=function(){if(this.typeNumber<1){var t=1;for(t=1;t<40;t++){for(var e=u.getRSBlocks(t,this.errorCorrectLevel),r=new h,n=0,o=0;o<e.length;o++)n+=e[o].dataCount;for(o=0;o<this.dataList.length;o++){var i=this.dataList[o];r.put(i.mode,4),r.put(i.getLength(),k.getLengthInBits(i.mode,t)),i.write(r)}if(r.getLengthInBits()<=8*n)break}this.typeNumber=t}this.makeImpl(!1,this.getBestMaskPattern())},T.makeImpl=function(t,e){this.moduleCount=4*this.typeNumber+17,this.modules=Array(this.moduleCount);for(var r=0;r<this.moduleCount;r++){this.modules[r]=Array(this.moduleCount);for(var n=0;n<this.moduleCount;n++)this.modules[r][n]=null}this.setupPositionProbePattern(0,0),this.setupPositionProbePattern(this.moduleCount-7,0),this.setupPositionProbePattern(0,this.moduleCount-7),this.setupPositionAdjustPattern(),this.setupTimingPattern(),this.setupTypeInfo(t,e),this.typeNumber<7||this.setupTypeNumber(t),null==this.dataCache&&(this.dataCache=D.createData(this.typeNumber,this.errorCorrectLevel,this.dataList)),this.mapData(this.dataCache,e)},T.setupPositionProbePattern=function(t,e){for(var r=-1;r<=7;r++)if(-1<t+r&&t+r<this.moduleCount)for(var n=-1;n<=7;n++)-1<e+n&&e+n<this.moduleCount&&(this.modules[t+r][e+n]=!((r<0||6<r||0!=n&&6!=n)&&(n<0||6<n||0!=r&&6!=r)&&(r<2||4<r||n<2||4<n)))},T.getBestMaskPattern=function(){for(var t=0,e=0,r=0;r<8;r++){this.makeImpl(!0,r);var n=k.getLostPoint(this);0!=r&&t<=n||(t=n,e=r)}return e},T.createMovieClip=function(t,e,r){var n=t.createEmptyMovieClip(e,r);this.make();for(var o=0;o<this.modules.length;o++)for(var i=1*o,a=0;a<this.modules[o].length;a++){var s=1*a;this.modules[o][a]&&(n.beginFill(0,100),n.moveTo(s,i),n.lineTo(1+s,i),n.lineTo(1+s,1+i),n.lineTo(s,1+i),n.endFill())}return n},T.setupTimingPattern=function(){for(var t=8;t<this.moduleCount-8;t++)null==this.modules[t][6]&&(this.modules[t][6]=t%2==0);for(var e=8;e<this.moduleCount-8;e++)null==this.modules[6][e]&&(this.modules[6][e]=e%2==0)},T.setupPositionAdjustPattern=function(){for(var t=k.getPatternPosition(this.typeNumber),e=0;e<t.length;e++)for(var r=0;r<t.length;r++){var n=t[e],o=t[r];if(null==this.modules[n][o])for(var i=-2;i<=2;i++)for(var a=-2;a<=2;a++)this.modules[n+i][o+a]=-2==i||2==i||-2==a||2==a||0==i&&0==a}},T.setupTypeNumber=function(t){for(var e=k.getBCHTypeNumber(this.typeNumber),r=0;r<18;r++){var n=!t&&1==(e>>r&1);this.modules[Math.floor(r/3)][r%3+this.moduleCount-8-3]=n}for(r=0;r<18;r++){n=!t&&1==(e>>r&1);this.modules[r%3+this.moduleCount-8-3][Math.floor(r/3)]=n}},T.setupTypeInfo=function(t,e){for(var r=k.getBCHTypeInfo(this.errorCorrectLevel<<3|e),n=0;n<15;n++){var o=!t&&1==(r>>n&1);n<6?this.modules[n][8]=o:n<8?this.modules[n+1][8]=o:this.modules[this.moduleCount-15+n][8]=o}for(n=0;n<15;n++){o=!t&&1==(r>>n&1);n<8?this.modules[8][this.moduleCount-n-1]=o:n<9?this.modules[8][15-n-1+1]=o:this.modules[8][15-n-1]=o}this.modules[this.moduleCount-8][8]=!t},T.mapData=function(t,e){for(var r=-1,n=this.moduleCount-1,o=7,i=0,a=this.moduleCount-1;0<a;a-=2)for(6==a&&a--;;){for(var s=0;s<2;s++)if(null==this.modules[n][a-s]){var u=!1;i<t.length&&(u=1==(t[i]>>>o&1)),k.getMask(e,n,a-s)&&(u=!u),this.modules[n][a-s]=u,-1==--o&&(i++,o=7)}if((n+=r)<0||this.moduleCount<=n){n-=r,r=-r;break}}},D.PAD0=236,D.PAD1=17,D.createData=function(t,e,r){for(var n=u.getRSBlocks(t,e),o=new h,i=0;i<r.length;i++){var a=r[i];o.put(a.mode,4),o.put(a.getLength(),k.getLengthInBits(a.mode,t)),a.write(o)}var s=0;for(i=0;i<n.length;i++)s+=n[i].dataCount;if(o.getLengthInBits()>8*s)throw Error("code length overflow. ("+o.getLengthInBits()+">"+8*s+")");for(o.getLengthInBits()+4>8*s||o.put(0,4);o.getLengthInBits()%8!=0;)o.putBit(!1);for(;o.getLengthInBits()<8*s&&(o.put(D.PAD0,8),o.getLengthInBits()<8*s);)o.put(D.PAD1,8);return D.createBytes(o,n)},D.createBytes=function(t,e){for(var r=0,n=0,o=0,i=Array(e.length),a=Array(e.length),s=0;s<e.length;s++){var u=e[s].dataCount,h=e[s].totalCount-u;n=Math.max(n,u),o=Math.max(o,h),i[s]=Array(u);for(var l=0;l<i[s].length;l++)i[s][l]=255&t.buffer[l+r];r+=u;var f=k.getErrorCorrectPolynomial(h),g=new p(i[s],f.getLength()-1).mod(f);a[s]=Array(f.getLength()-1);for(l=0;l<a[s].length;l++){var c=l+g.getLength()-a[s].length;a[s][l]=c<0?0:g.get(c)}}var d=0;for(l=0;l<e.length;l++)d+=e[l].totalCount;var m=Array(d),v=0;for(l=0;l<n;l++)for(s=0;s<e.length;s++)l<i[s].length&&(m[v++]=i[s][l]);for(l=0;l<o;l++)for(s=0;s<e.length;s++)l<a[s].length&&(m[v++]=a[s][l]);return m};var b=D;return{props:{value:{type:String,required:!0,default:""},className:{type:String,default:""},size:{type:[Number,String],default:100,validator:function(t){return!0!==isNaN(+t)}},level:{type:String,default:"L",validator:function(t){return!!~["L","Q","M","H"].indexOf(t)}},background:{type:String,default:"#fff"},foreground:{type:String,default:"#000"},renderAs:{type:String,required:!1,default:"canvas",validator:function(t){return!!~["canvas","svg"].indexOf(t)}}},data:function(){return{numCells:0,fgPath:""}},updated:function(){this.render()},mounted:function(){this.render()},methods:{render:function(){var t=this.value,i=this.background,a=this.foreground,e=this.renderAs,r=this.size>>>0,n=new b(-1,g[this.level]);n.addData(function(t){for(var e="",r=0;r<t.length;r++){var n=t.charCodeAt(r);n<128?e+=String.fromCharCode(n):(n<2048?e+=String.fromCharCode(192|n>>6):(n<55296||57344<=n?e+=String.fromCharCode(224|n>>12):(n=65536+((1023&n)<<10|1023&t.charCodeAt(++r)),e+=String.fromCharCode(240|n>>18),e+=String.fromCharCode(128|n>>12&63)),e+=String.fromCharCode(128|n>>6&63)),e+=String.fromCharCode(128|63&n))}return e}(t)),n.make();var o=n.modules,s=r/o.length,u=r/o.length,h=window.devicePixelRatio||1;if("svg"===e)this.numCells=o.length,this.fgPath=function(t,e){var i=1<arguments.length&&void 0!==e?e:0,a=[];return t.forEach(function(r,n){var o=null;r.forEach(function(t,e){if(!t&&null!==o)return a.push("M".concat(o+i," ").concat(n+i,"h").concat(e-o,"v1H").concat(o+i,"z")),void(o=null);if(e!==r.length-1)t&&null===o&&(o=e);else{if(!t)return;a.push(null===o?"M".concat(e+i,",").concat(n+i," h1v1H").concat(e+i,"z"):"M".concat(o+i,",").concat(n+i," h").concat(e+1-o,"v1H").concat(o+i,"z"))}})}),a.join("")}(o);else{var l=this.$refs["qrcode-vue"],f=l.getContext("2d");l.height=l.width=r*h,f.scale(h,h),o.forEach(function(t,o){t.forEach(function(t,e){f.fillStyle=t?a:i;var r=Math.ceil((e+1)*s)-Math.floor(e*s),n=Math.ceil((o+1)*u)-Math.floor(o*u);f.fillRect(Math.round(e*s),Math.round(o*u),r,n)})})}}},render:function(t){var e=this.background,r=this.foreground,n=this.size,o=this.numCells,i=this.fgPath;return t("div",{class:this.class||this.className,attrs:{value:this.value,level:this.level,background:e,foreground:r}},["svg"===this.renderAs?t("svg",{attrs:{height:n,width:n,shapeRendering:"crispEdges",viewBox:"0 0 ".concat(o," ").concat(o)},style:{width:n+"px",height:n+"px"}},[t("path",{attrs:{fill:e,d:"M0,0 h".concat(o,"v").concat(o,"H0z")}}),t("path",{attrs:{fill:r,d:i}})]):t("canvas",{attrs:{height:n,width:n},style:{width:n+"px",height:n+"px"},ref:"qrcode-vue"},[])])}}});

@@ -10,2 +10,5 @@ import Vue from 'vue'

el: '#root',
components: {
QrcodeVue,
},
data: {

@@ -17,6 +20,7 @@ value: 'https://example.com',

foreground: '#000000',
renderAs: 'svg',
},
template: `<form class="form-horizontal">
<div class="form-group">
<label for="inputEmail3" class="col-sm-2 control-label">Value:</label>
<label class="col-sm-2 control-label">Value:</label>
<div class="col-sm-10">

@@ -27,6 +31,6 @@ <textarea v-model="value" class="form-control" rows="3"></textarea>

<div class="form-group">
<label for="inputPassword3" class="col-sm-2 control-label">Size:</label>
<label class="col-sm-2 control-label">Size:</label>
<div class="col-sm-10">
<div class="form-control-static">
<input type="range" v-model="size" min="100" max="800">
<input type="range" v-model="size" min="100" max="800" step="20">
</div>

@@ -36,4 +40,13 @@ </div>

<div class="form-group">
<label for="inputPassword3" class="col-sm-2 control-label">Level:</label>
<label class="col-sm-2 control-label">Level:</label>
<div class="col-sm-10">
<select v-model="renderAs" class="form-control">
<option value="svg">svg</option>
<option value="canvas">canvas</option>
</select>
</div>
</div>
<div class="form-group">
<label class="col-sm-2 control-label">Level:</label>
<div class="col-sm-10">
<select v-model="level" class="form-control">

@@ -48,3 +61,3 @@ <option value="L">L</option>

<div class="form-group">
<label for="inputPassword3" class="col-sm-2 control-label">Background:</label>
<label class="col-sm-2 control-label">Background:</label>
<div class="col-sm-10">

@@ -57,3 +70,3 @@ <div class="form-control-static">

<div class="form-group">
<label for="inputPassword3" class="col-sm-2 control-label">Foreground:</label>
<label class="col-sm-2 control-label">Foreground:</label>
<div class="col-sm-10">

@@ -66,6 +79,6 @@ <div class="form-control-static">

<div class="form-group">
<label for="inputPassword3" class="col-sm-2 control-label">QR_CODE:</label>
<label class="col-sm-2 control-label">QR_CODE:</label>
<div class="col-sm-10">
<div class="form-control-static">
<qrcode-vue class="qrcode" :value="value" :size="size" :level="level" :background="background" :foreground="foreground"/>
<qrcode-vue class="qrcode" :value="value" :renderAs="renderAs" :size="size" :level="level" :background="background" :foreground="foreground"/>
</div>

@@ -75,5 +88,2 @@ </div>

</form>`,
components: {
QrcodeVue,
},
})
{
"name": "qrcode.vue",
"version": "1.6.3",
"description": "A Vue component for QRCode.",
"version": "1.7.0",
"description": "A Vue component to generate QRCode.",
"main": "dist/qrcode.vue.js",

@@ -26,3 +26,4 @@ "module": "dist/qrcode.vue.esm.js",

"code",
"qrcode"
"qrcode",
"二维码"
],

@@ -29,0 +30,0 @@ "files": [

@@ -84,2 +84,9 @@ # qrcode.vue

### renderAs
- Type: `string`
- Default: `canvas`
生成二维码的 HTML 标签,可选 `canvas` 或 `svg`。
### background

@@ -86,0 +93,0 @@

# qrcode.vue
A Vue.js component for [QRCode](https://en.wikipedia.org/wiki/QR_code).
A Vue.js component to generate [QRCode](https://en.wikipedia.org/wiki/QR_code).

@@ -86,2 +86,9 @@ [![Build Status](https://travis-ci.org/scopewu/qrcode.vue.svg?branch=master)](https://travis-ci.org/scopewu/qrcode.vue)

### renderAs
- Type: `string`
- Default: `canvas`
Generate QRcode as `canvas` or `svg`.
### background

@@ -88,0 +95,0 @@

@@ -40,2 +40,45 @@ import QRCode from 'qr.js/lib/QRCode'

function generatePath(modules, margin = 0) {
const ops = []
modules.forEach(function(row, y) {
let start = null
row.forEach(function(cell, x) {
if (!cell && start !== null) {
// M0 0h7v1H0z injects the space with the move and drops the comma,
// saving a char per operation
ops.push(
`M${start + margin} ${y + margin}h${x - start}v1H${start + margin}z`
)
start = null
return
}
// end of row, clean up or skip
if (x === row.length - 1) {
if (!cell) {
// We would have closed the op above already so this can only mean
// 2+ light modules in a row.
return
}
if (start === null) {
// Just a single dark module.
ops.push(`M${x + margin},${y + margin} h1v1H${x + margin}z`)
} else {
// Otherwise finish the current line.
ops.push(
`M${start + margin},${y + margin} h${x + 1 - start}v1H${start +
margin}z`
)
}
return
}
if (cell && start === null) {
start = x
}
})
})
return ops.join('')
}
// @vue/component

@@ -71,3 +114,15 @@ const QrcodeVue = {

},
renderAs: {
type: String,
required: false,
default: 'canvas',
validator: (as) => ['canvas', 'svg'].indexOf(as) > -1,
},
},
data() {
return {
numCells: 0,
fgPath: '',
}
},
updated() {

@@ -81,3 +136,3 @@ this.render()

render() {
const { value, size, level, background, foreground } = this
const { value, size, level, background, foreground, renderAs } = this
const _size = size >>> 0 // size to number

@@ -90,5 +145,2 @@

const canvas = this.$refs['qrcode-vue']
const ctx = canvas.getContext('2d')
const cells = qrCode.modules

@@ -98,17 +150,43 @@ const tileW = _size / cells.length

const scale = window.devicePixelRatio || 1
canvas.height = canvas.width = _size * scale
ctx.scale(scale, scale)
cells.forEach(function(row, rdx) {
row.forEach(function(cell, cdx) {
ctx.fillStyle = cell ? foreground : background
const w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW)
const h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH)
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h)
if (renderAs === 'svg') {
this.numCells = cells.length
// Drawing strategy: instead of a rect per module, we're going to create a
// single path for the dark modules and layer that on top of a light rect,
// for a total of 2 DOM nodes. We pay a bit more in string concat but that's
// way faster than DOM ops.
// For level 1, 441 nodes -> 2
// For level 40, 31329 -> 2
this.fgPath = generatePath(cells);
} else {
const canvas = this.$refs['qrcode-vue']
const ctx = canvas.getContext('2d')
canvas.height = canvas.width = _size * scale
ctx.scale(scale, scale)
cells.forEach(function(row, rdx) {
row.forEach(function(cell, cdx) {
ctx.fillStyle = cell ? foreground : background
const w = Math.ceil((cdx + 1) * tileW) - Math.floor(cdx * tileW)
const h = Math.ceil((rdx + 1) * tileH) - Math.floor(rdx * tileH)
ctx.fillRect(Math.round(cdx * tileW), Math.round(rdx * tileH), w, h)
})
})
})
}
},
},
render(createElement) {
const { className, value, level, background, foreground, size } = this
const {
className,
value,
level,
background,
foreground,
size,
renderAs,
numCells,
fgPath,
} = this

@@ -122,11 +200,35 @@ return createElement(

[
createElement(
'canvas',
{
attrs: { height: size, width: size },
style: { width: size + 'px', height: size + 'px' },
ref: 'qrcode-vue',
},
[]
),
renderAs === 'svg'
? createElement(
'svg',
{
attrs: {
height: size,
width: size,
shapeRendering: 'crispEdges',
viewBox: `0 0 ${numCells} ${numCells}`,
},
style: { width: size + 'px', height: size + 'px' },
},
[
createElement('path', {
attrs: {
fill: background,
d: `M0,0 h${numCells}v${numCells}H0z`,
},
}),
createElement('path', {
attrs: { fill: foreground, d: fgPath },
}),
]
)
: createElement(
'canvas',
{
attrs: { height: size, width: size },
style: { width: size + 'px', height: size + 'px' },
ref: 'qrcode-vue',
},
[]
),
]

@@ -133,0 +235,0 @@ )

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc