yh-hiprint 2.4.2 → 2.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -20,13 +20,13 @@ import {hiprint} from 'yh-hiprint';
20
20
  function getQuery() {
21
21
  let query = {};
22
22
  try {
23
- decodeURIComponent(location.hash)
23
+ location.hash
24
24
  .split('?')[1]
25
25
  .split('&')
26
26
  .forEach((str) => {
27
27
  let index = str.indexOf('=');
28
28
  let key = str.substring(0, index);
29
- let value = str.substring(index + 1);
29
+ let value = decodeURIComponent(str.substring(index + 1));
30
30
  query[key] = value;
31
31
  });
32
32
  } catch (error) {
package/index.js CHANGED
@@ -1,19 +1,19 @@
1
- import "./libs/jquery";
2
- export { hiprint, defaultElementTypeProvider, print, print2, usePaper, useScale, useDataSource } from "./hooks/useHiprint";
3
- export { default as fontSize } from "./font-size";
4
- export { default as scale } from "./scale";
5
- export { default as zIndex } from "./z-index";
6
- export { default as panel } from "./panel";
1
+ import './libs/jquery';
2
+ export {hiprint, defaultElementTypeProvider, print, print2, usePaper, useScale, useDataSource} from './hooks/useHiprint';
3
+ export {default as fontSize} from './font-size';
4
+ export {default as scale} from './scale';
5
+ export {default as zIndex} from './z-index';
6
+ export {default as panel} from './panel';
7
7
 
8
- export function cLog (string, isError = false) {
8
+ export function cLog(string, isError = false) {
9
9
  if (isError) {
10
- console.error("%cyhHiprint:%c", "font-size: 16px;font-weight: bold;color: #00ffff", "font-size: 16px;font-weight: bold;color: #ccccc", string);
10
+ console.error('%cyhHiprint:%c', 'font-size: 16px;font-weight: bold;color: #00ffff', 'font-size: 16px;font-weight: bold;color: #ccccc', string);
11
11
  } else {
12
- console.log("%cyhHiprint%c " + string, "font-size: 18px;font-weight: bold;color: #61AFEF", "font-size: 12px;color: #999");
12
+ console.log('%cyhHiprint%c ' + string, 'font-size: 18px;font-weight: bold;color: #61AFEF', 'font-size: 12px;color: #999');
13
13
  }
14
14
  }
15
15
 
16
- const hiprint = ({ code, params, data, isCustom }) => {
16
+ const hiprint = ({code, params, data, isCustom}) => {
17
17
  let height = document.documentElement.clientHeight;
18
18
  let width = (document.documentElement.clientWidth - 1200) / 2;
19
19
  // 转换数组
@@ -21,43 +21,43 @@ const hiprint = ({ code, params, data, isCustom }) => {
21
21
  if (!Array.isArray(params)) {
22
22
  paramData = [params];
23
23
  }
24
- let url = "/hiprint/#/preview?code=" + code;
24
+ let url = '/hiprint/#/preview?code=' + encodeURIComponent(code);
25
25
  if (params) {
26
- url += `&params=${JSON.stringify(paramData)}`;
26
+ url += `&params=${encodeURIComponent(JSON.stringify(paramData))}`;
27
27
  }
28
28
  if (data) {
29
- url += `&data=${JSON.stringify(data)}`;
29
+ url += `&data=${encodeURIComponent(JSON.stringify(data))}`;
30
30
  }
31
31
  if (isCustom) {
32
- url += `&isCustom=${isCustom ? "1" : "0"}`;
32
+ url += `&isCustom=${isCustom ? '1' : '0'}`;
33
33
  }
34
- let windowOpen = window.open(url, "hiprintWindow", `height=${height}, width=1200, top=20, left=${width}, toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no`);
34
+ let windowOpen = window.open(url, 'hiprintWindow', `height=${height}, width=1200, top=20, left=${width}, toolbar=no, menubar=no, scrollbars=no, resizable=no, location=no, status=no`);
35
35
  };
36
36
  export default {
37
- install (app, { router, pinia, isAdmin }) {
38
- app.provide("$hiprint", hiprint);
37
+ install(app, {router, pinia, isAdmin}) {
38
+ app.provide('$hiprint', hiprint);
39
39
  if (router) {
40
- router.addRoute("Index", {
41
- path: "hiprint/designer",
42
- name: "打印设计器",
40
+ router.addRoute('Index', {
41
+ path: 'hiprint/designer',
42
+ name: '打印设计器',
43
43
  meta: {
44
- icon: "md-planet",
45
- title: "打印设计器",
44
+ icon: 'md-planet',
45
+ title: '打印设计器',
46
46
  },
47
- component: () => import("yh-hiprint/HiprintDesigner.vue"),
47
+ component: () => import('yh-hiprint/HiprintDesigner.vue'),
48
48
  });
49
49
  router.addRoute({
50
- path: "/preview",
51
- name: "printView",
50
+ path: '/preview',
51
+ name: 'printView',
52
52
  meta: {
53
- icon: "md-planet",
54
- title: "printView",
53
+ icon: 'md-planet',
54
+ title: 'printView',
55
55
  },
56
- component: () => import("yh-hiprint/hiprintPreview.vue"),
56
+ component: () => import('yh-hiprint/hiprintPreview.vue'),
57
57
  });
58
58
  } else {
59
59
  if (!router) {
60
- cLog("没有传递 router 对象,所以无法将路由添加到应用中", true);
60
+ cLog('没有传递 router 对象,所以无法将路由添加到应用中', true);
61
61
  }
62
62
  }
63
63
  },
@@ -11,27 +11,6 @@
11
11
 
12
12
  "use strict";
13
13
 
14
- function _instanceof (left, right) {
15
- if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
16
- return !!right[Symbol.hasInstance](left);
17
- } else {
18
- return left instanceof right;
19
- }
20
- }
21
-
22
- function _typeof (obj) {
23
- if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
24
- _typeof = function _typeof (obj) {
25
- return typeof obj;
26
- };
27
- } else {
28
- _typeof = function _typeof (obj) {
29
- return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
30
- };
31
- }
32
- return _typeof(obj);
33
- }
34
-
35
14
  /**
36
15
  * import 相关资源
37
16
  */
@@ -40,7 +19,7 @@ import "./plugins/jquery.minicolors.js";
40
19
  // 条形码
41
20
  import JsBarcode from "./jsbarcode/JsBarcode.js";
42
21
  // 二维码
43
- import "./plugins/qrcode.js";
22
+ import QRCode from "./plugins/qrcode.js";
44
23
  // 水印
45
24
  import watermark from "./plugins/watermark.js";
46
25
  // 直接打印需要
@@ -56,6 +35,27 @@ import { Canvg } from "canvg";
56
35
  // 默认自定义拖拽列表
57
36
  import defaultTypeProvider from "./etypes/default-etyps-provider";
58
37
 
38
+ function _instanceof (left, right) {
39
+ if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
40
+ return !!right[Symbol.hasInstance](left);
41
+ } else {
42
+ return left instanceof right;
43
+ }
44
+ }
45
+
46
+ function _typeof (obj) {
47
+ if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
48
+ _typeof = function _typeof (obj) {
49
+ return typeof obj;
50
+ };
51
+ } else {
52
+ _typeof = function _typeof (obj) {
53
+ return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
54
+ };
55
+ }
56
+ return _typeof(obj);
57
+ }
58
+
59
59
  window.autoConnect = true;
60
60
 
61
61
  var hiprint = (function (t) {
@@ -2290,6 +2290,7 @@ var hiprint = (function (t) {
2290
2290
  colorDark: "#000000",
2291
2291
  useSVG: !0,
2292
2292
  correctLevel: t.tableQRCodeLevel || 0,
2293
+ typeNumber
2293
2294
  }).makeCode(p);
2294
2295
  r.html(qrcodebox);
2295
2296
  }
@@ -10047,7 +10048,13 @@ var hiprint = (function (t) {
10047
10048
  return (null == this.barcodeMode ? this.defaultOptions.barcodeMode : this.barcodeMode) || "CODE128";
10048
10049
  }),
10049
10050
  (e.prototype.getQRcodeLevel = function () {
10050
- return (null == this.qrCodeLevel ? this.defaultOptions.qrCodeLevel : this.qrCodeLevel) || 0;
10051
+ let levelMap = {
10052
+ 1: "L",
10053
+ 0: "M",
10054
+ 3: "Q",
10055
+ 2: "H",
10056
+ };
10057
+ return (null == this.qrCodeLevel ? 'L' : levelMap[this.qrCodeLevel]) || 'L';
10051
10058
  }),
10052
10059
  e
10053
10060
  );
@@ -10172,14 +10179,23 @@ var hiprint = (function (t) {
10172
10179
  width: (lpt > upt ? upt : lpt) + "pt",
10173
10180
  height: (lpt > upt ? upt : lpt) + "pt",
10174
10181
  display: "inline-block",
10182
+ backgroundSize: "100% 100%",
10183
+ backgroundRepeat: "no-repeat",
10184
+ backgroundPosition: "center center",
10185
+ backgroundImage: "url(" + QRCode({
10186
+ level: this.options.getQRcodeLevel(),
10187
+ fnc1: 'None',
10188
+ mode: 'Auto',
10189
+ moduleSize: 8,
10190
+ quietZone: 0,
10191
+ aimIndicator: 0,
10192
+ version: 'Auto',
10193
+ charset: 'UTF_8',
10194
+ background: '#ffffff',
10195
+ foreground: this.options.color || "#000000",
10196
+ content: n
10197
+ }) + ")",
10175
10198
  });
10176
- new QRCode(box[0], {
10177
- width: "100%",
10178
- height: "100%",
10179
- colorDark: this.options.color || "#000000",
10180
- useSVG: !0,
10181
- correctLevel: this.options.getQRcodeLevel(),
10182
- }).makeCode(n);
10183
10199
  a.html(box);
10184
10200
  }
10185
10201
  } catch (t) {
@@ -1,617 +1,86 @@
1
- /**
2
- * @fileoverview
3
- * - Using the 'QRCode for Javascript library'
4
- * - Fixed dataset of 'QRCode for Javascript library' for support full-spec.
5
- * - this library has no dependencies.
6
- *
7
- * @author davidshimjs
8
- * @see <a href="http://www.d-project.com/" target="_blank">http://www.d-project.com/</a>
9
- * @see <a href="http://jeromeetienne.github.com/jquery-qrcode/" target="_blank">http://jeromeetienne.github.com/jquery-qrcode/</a>
10
- */
11
-
12
- window.QRCode;
13
- (function () {
14
-
15
- //---------------------------------------------------------------------
16
- // QRCode for JavaScript
17
- //
18
- // Copyright (c) 2009 Kazuhiko Arase
19
- //
20
- // URL: http://www.d-project.com/
21
- //
22
- // Licensed under the MIT license:
23
- // http://www.opensource.org/licenses/mit-license.php
24
- //
25
- // The word "QR Code" is registered trademark of
26
- // DENSO WAVE INCORPORATED
27
- // http://www.denso-wave.com/qrcode/faqpatent-e.html
28
- //
29
- //---------------------------------------------------------------------
30
- function QR8bitByte(data) {
31
- this.mode = QRMode.MODE_8BIT_BYTE;
32
- this.data = data;
33
- this.parsedData = [];
34
-
35
- // Added to support UTF-8 Characters
36
- for (var i = 0, l = this.data.length; i < l; i++) {
37
- var byteArray = [];
38
- var code = this.data.charCodeAt(i);
39
-
40
- if (code > 0x10000) {
41
- byteArray[0] = 0xF0 | ((code & 0x1C0000) >>> 18);
42
- byteArray[1] = 0x80 | ((code & 0x3F000) >>> 12);
43
- byteArray[2] = 0x80 | ((code & 0xFC0) >>> 6);
44
- byteArray[3] = 0x80 | (code & 0x3F);
45
- } else if (code > 0x800) {
46
- byteArray[0] = 0xE0 | ((code & 0xF000) >>> 12);
47
- byteArray[1] = 0x80 | ((code & 0xFC0) >>> 6);
48
- byteArray[2] = 0x80 | (code & 0x3F);
49
- } else if (code > 0x80) {
50
- byteArray[0] = 0xC0 | ((code & 0x7C0) >>> 6);
51
- byteArray[1] = 0x80 | (code & 0x3F);
52
- } else {
53
- byteArray[0] = code;
54
- }
55
-
56
- this.parsedData.push(byteArray);
57
- }
58
-
59
- this.parsedData = Array.prototype.concat.apply([], this.parsedData);
60
-
61
- if (this.parsedData.length != this.data.length) {
62
- this.parsedData.unshift(191);
63
- this.parsedData.unshift(187);
64
- this.parsedData.unshift(239);
65
- }
66
- }
67
-
68
- QR8bitByte.prototype = {
69
- getLength: function (buffer) {
70
- return this.parsedData.length;
71
- },
72
- write: function (buffer) {
73
- for (var i = 0, l = this.parsedData.length; i < l; i++) {
74
- buffer.put(this.parsedData[i], 8);
75
- }
76
- }
77
- };
78
-
79
- function QRCodeModel(typeNumber, errorCorrectLevel) {
80
- this.typeNumber = typeNumber;
81
- this.errorCorrectLevel = errorCorrectLevel;
82
- this.modules = null;
83
- this.moduleCount = 0;
84
- this.dataCache = null;
85
- this.dataList = [];
86
- }
87
-
88
- QRCodeModel.prototype={addData:function(data){var newData=new QR8bitByte(data);this.dataList.push(newData);this.dataCache=null;},isDark:function(row,col){if(row<0||this.moduleCount<=row||col<0||this.moduleCount<=col){throw new Error(row+","+col);}
89
- return this.modules[row][col];},getModuleCount:function(){return this.moduleCount;},make:function(){this.makeImpl(false,this.getBestMaskPattern());},makeImpl:function(test,maskPattern){this.moduleCount=this.typeNumber*4+17;this.modules=new Array(this.moduleCount);for(var row=0;row<this.moduleCount;row++){this.modules[row]=new Array(this.moduleCount);for(var col=0;col<this.moduleCount;col++){this.modules[row][col]=null;}}
90
- this.setupPositionProbePattern(0,0);this.setupPositionProbePattern(this.moduleCount-7,0);this.setupPositionProbePattern(0,this.moduleCount-7);this.setupPositionAdjustPattern();this.setupTimingPattern();this.setupTypeInfo(test,maskPattern);if(this.typeNumber>=7){this.setupTypeNumber(test);}
91
- if(this.dataCache==null){this.dataCache=QRCodeModel.createData(this.typeNumber,this.errorCorrectLevel,this.dataList);}
92
- this.mapData(this.dataCache,maskPattern);},setupPositionProbePattern:function(row,col){for(var r=-1;r<=7;r++){if(row+r<=-1||this.moduleCount<=row+r)continue;for(var c=-1;c<=7;c++){if(col+c<=-1||this.moduleCount<=col+c)continue;if((0<=r&&r<=6&&(c==0||c==6))||(0<=c&&c<=6&&(r==0||r==6))||(2<=r&&r<=4&&2<=c&&c<=4)){this.modules[row+r][col+c]=true;}else{this.modules[row+r][col+c]=false;}}}},getBestMaskPattern:function(){var minLostPoint=0;var pattern=0;for(var i=0;i<8;i++){this.makeImpl(true,i);var lostPoint=QRUtil.getLostPoint(this);if(i==0||minLostPoint>lostPoint){minLostPoint=lostPoint;pattern=i;}}
93
- return pattern;},createMovieClip:function(target_mc,instance_name,depth){var qr_mc=target_mc.createEmptyMovieClip(instance_name,depth);var cs=1;this.make();for(var row=0;row<this.modules.length;row++){var y=row*cs;for(var col=0;col<this.modules[row].length;col++){var x=col*cs;var dark=this.modules[row][col];if(dark){qr_mc.beginFill(0,100);qr_mc.moveTo(x,y);qr_mc.lineTo(x+cs,y);qr_mc.lineTo(x+cs,y+cs);qr_mc.lineTo(x,y+cs);qr_mc.endFill();}}}
94
- return qr_mc;},setupTimingPattern:function(){for(var r=8;r<this.moduleCount-8;r++){if(this.modules[r][6]!=null){continue;}
95
- this.modules[r][6]=(r%2==0);}
96
- for(var c=8;c<this.moduleCount-8;c++){if(this.modules[6][c]!=null){continue;}
97
- this.modules[6][c]=(c%2==0);}},setupPositionAdjustPattern:function(){var pos=QRUtil.getPatternPosition(this.typeNumber);for(var i=0;i<pos.length;i++){for(var j=0;j<pos.length;j++){var row=pos[i];var col=pos[j];if(this.modules[row][col]!=null){continue;}
98
- for(var r=-2;r<=2;r++){for(var c=-2;c<=2;c++){if(r==-2||r==2||c==-2||c==2||(r==0&&c==0)){this.modules[row+r][col+c]=true;}else{this.modules[row+r][col+c]=false;}}}}}},setupTypeNumber:function(test){var bits=QRUtil.getBCHTypeNumber(this.typeNumber);for(var i=0;i<18;i++){var mod=(!test&&((bits>>i)&1)==1);this.modules[Math.floor(i/3)][i%3+this.moduleCount-8-3]=mod;}
99
- for(var i=0;i<18;i++){var mod=(!test&&((bits>>i)&1)==1);this.modules[i%3+this.moduleCount-8-3][Math.floor(i/3)]=mod;}},setupTypeInfo:function(test,maskPattern){var data=(this.errorCorrectLevel<<3)|maskPattern;var bits=QRUtil.getBCHTypeInfo(data);for(var i=0;i<15;i++){var mod=(!test&&((bits>>i)&1)==1);if(i<6){this.modules[i][8]=mod;}else if(i<8){this.modules[i+1][8]=mod;}else{this.modules[this.moduleCount-15+i][8]=mod;}}
100
- for(var i=0;i<15;i++){var mod=(!test&&((bits>>i)&1)==1);if(i<8){this.modules[8][this.moduleCount-i-1]=mod;}else if(i<9){this.modules[8][15-i-1+1]=mod;}else{this.modules[8][15-i-1]=mod;}}
101
- this.modules[this.moduleCount-8][8]=(!test);},mapData:function(data,maskPattern){var inc=-1;var row=this.moduleCount-1;var bitIndex=7;var byteIndex=0;for(var col=this.moduleCount-1;col>0;col-=2){if(col==6)col--;while(true){for(var c=0;c<2;c++){if(this.modules[row][col-c]==null){var dark=false;if(byteIndex<data.length){dark=(((data[byteIndex]>>>bitIndex)&1)==1);}
102
- var mask=QRUtil.getMask(maskPattern,row,col-c);if(mask){dark=!dark;}
103
- this.modules[row][col-c]=dark;bitIndex--;if(bitIndex==-1){byteIndex++;bitIndex=7;}}}
104
- row+=inc;if(row<0||this.moduleCount<=row){row-=inc;inc=-inc;break;}}}}};QRCodeModel.PAD0=0xEC;QRCodeModel.PAD1=0x11;QRCodeModel.createData=function(typeNumber,errorCorrectLevel,dataList){var rsBlocks=QRRSBlock.getRSBlocks(typeNumber,errorCorrectLevel);var buffer=new QRBitBuffer();for(var i=0;i<dataList.length;i++){var data=dataList[i];buffer.put(data.mode,4);buffer.put(data.getLength(),QRUtil.getLengthInBits(data.mode,typeNumber));data.write(buffer);}
105
- var totalDataCount=0;for(var i=0;i<rsBlocks.length;i++){totalDataCount+=rsBlocks[i].dataCount;}
106
- if(buffer.getLengthInBits()>totalDataCount*8){throw new Error("code length overflow. ("
107
- +buffer.getLengthInBits()
108
- +">"
109
- +totalDataCount*8
110
- +")");}
111
- if(buffer.getLengthInBits()+4<=totalDataCount*8){buffer.put(0,4);}
112
- while(buffer.getLengthInBits()%8!=0){buffer.putBit(false);}
113
- while(true){if(buffer.getLengthInBits()>=totalDataCount*8){break;}
114
- buffer.put(QRCodeModel.PAD0,8);if(buffer.getLengthInBits()>=totalDataCount*8){break;}
115
- buffer.put(QRCodeModel.PAD1,8);}
116
- return QRCodeModel.createBytes(buffer,rsBlocks);};QRCodeModel.createBytes=function(buffer,rsBlocks){var offset=0;var maxDcCount=0;var maxEcCount=0;var dcdata=new Array(rsBlocks.length);var ecdata=new Array(rsBlocks.length);for(var r=0;r<rsBlocks.length;r++){var dcCount=rsBlocks[r].dataCount;var ecCount=rsBlocks[r].totalCount-dcCount;maxDcCount=Math.max(maxDcCount,dcCount);maxEcCount=Math.max(maxEcCount,ecCount);dcdata[r]=new Array(dcCount);for(var i=0;i<dcdata[r].length;i++){dcdata[r][i]=0xff&buffer.buffer[i+offset];}
117
- offset+=dcCount;var rsPoly=QRUtil.getErrorCorrectPolynomial(ecCount);var rawPoly=new QRPolynomial(dcdata[r],rsPoly.getLength()-1);var modPoly=rawPoly.mod(rsPoly);ecdata[r]=new Array(rsPoly.getLength()-1);for(var i=0;i<ecdata[r].length;i++){var modIndex=i+modPoly.getLength()-ecdata[r].length;ecdata[r][i]=(modIndex>=0)?modPoly.get(modIndex):0;}}
118
- var totalCodeCount=0;for(var i=0;i<rsBlocks.length;i++){totalCodeCount+=rsBlocks[i].totalCount;}
119
- var data=new Array(totalCodeCount);var index=0;for(var i=0;i<maxDcCount;i++){for(var r=0;r<rsBlocks.length;r++){if(i<dcdata[r].length){data[index++]=dcdata[r][i];}}}
120
- for(var i=0;i<maxEcCount;i++){for(var r=0;r<rsBlocks.length;r++){if(i<ecdata[r].length){data[index++]=ecdata[r][i];}}}
121
- return data;};var QRMode={MODE_NUMBER:1<<0,MODE_ALPHA_NUM:1<<1,MODE_8BIT_BYTE:1<<2,MODE_KANJI:1<<3};var QRErrorCorrectLevel={L:1,M:0,Q:3,H:2};var QRMaskPattern={PATTERN000:0,PATTERN001:1,PATTERN010:2,PATTERN011:3,PATTERN100:4,PATTERN101:5,PATTERN110:6,PATTERN111:7};var QRUtil={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:(1<<10)|(1<<8)|(1<<5)|(1<<4)|(1<<2)|(1<<1)|(1<<0),G18:(1<<12)|(1<<11)|(1<<10)|(1<<9)|(1<<8)|(1<<5)|(1<<2)|(1<<0),G15_MASK:(1<<14)|(1<<12)|(1<<10)|(1<<4)|(1<<1),getBCHTypeInfo:function(data){var d=data<<10;while(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G15)>=0){d^=(QRUtil.G15<<(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G15)));}
122
- return((data<<10)|d)^QRUtil.G15_MASK;},getBCHTypeNumber:function(data){var d=data<<12;while(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G18)>=0){d^=(QRUtil.G18<<(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G18)));}
123
- return(data<<12)|d;},getBCHDigit:function(data){var digit=0;while(data!=0){digit++;data>>>=1;}
124
- return digit;},getPatternPosition:function(typeNumber){return QRUtil.PATTERN_POSITION_TABLE[typeNumber-1];},getMask:function(maskPattern,i,j){switch(maskPattern){case QRMaskPattern.PATTERN000:return(i+j)%2==0;case QRMaskPattern.PATTERN001:return i%2==0;case QRMaskPattern.PATTERN010:return j%3==0;case QRMaskPattern.PATTERN011:return(i+j)%3==0;case QRMaskPattern.PATTERN100:return(Math.floor(i/2)+Math.floor(j/3))%2==0;case QRMaskPattern.PATTERN101:return(i*j)%2+(i*j)%3==0;case QRMaskPattern.PATTERN110:return((i*j)%2+(i*j)%3)%2==0;case QRMaskPattern.PATTERN111:return((i*j)%3+(i+j)%2)%2==0;default:throw new Error("bad maskPattern:"+maskPattern);}},getErrorCorrectPolynomial:function(errorCorrectLength){var a=new QRPolynomial([1],0);for(var i=0;i<errorCorrectLength;i++){a=a.multiply(new QRPolynomial([1,QRMath.gexp(i)],0));}
125
- return a;},getLengthInBits:function(mode,type){if(1<=type&&type<10){switch(mode){case QRMode.MODE_NUMBER:return 10;case QRMode.MODE_ALPHA_NUM:return 9;case QRMode.MODE_8BIT_BYTE:return 8;case QRMode.MODE_KANJI:return 8;default:throw new Error("mode:"+mode);}}else if(type<27){switch(mode){case QRMode.MODE_NUMBER:return 12;case QRMode.MODE_ALPHA_NUM:return 11;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 10;default:throw new Error("mode:"+mode);}}else if(type<41){switch(mode){case QRMode.MODE_NUMBER:return 14;case QRMode.MODE_ALPHA_NUM:return 13;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 12;default:throw new Error("mode:"+mode);}}else{throw new Error("type:"+type);}},getLostPoint:function(qrCode){var moduleCount=qrCode.getModuleCount();var lostPoint=0;for(var row=0;row<moduleCount;row++){for(var col=0;col<moduleCount;col++){var sameCount=0;var dark=qrCode.isDark(row,col);for(var r=-1;r<=1;r++){if(row+r<0||moduleCount<=row+r){continue;}
126
- for(var c=-1;c<=1;c++){if(col+c<0||moduleCount<=col+c){continue;}
127
- if(r==0&&c==0){continue;}
128
- if(dark==qrCode.isDark(row+r,col+c)){sameCount++;}}}
129
- if(sameCount>5){lostPoint+=(3+sameCount-5);}}}
130
- for(var row=0;row<moduleCount-1;row++){for(var col=0;col<moduleCount-1;col++){var count=0;if(qrCode.isDark(row,col))count++;if(qrCode.isDark(row+1,col))count++;if(qrCode.isDark(row,col+1))count++;if(qrCode.isDark(row+1,col+1))count++;if(count==0||count==4){lostPoint+=3;}}}
131
- for(var row=0;row<moduleCount;row++){for(var col=0;col<moduleCount-6;col++){if(qrCode.isDark(row,col)&&!qrCode.isDark(row,col+1)&&qrCode.isDark(row,col+2)&&qrCode.isDark(row,col+3)&&qrCode.isDark(row,col+4)&&!qrCode.isDark(row,col+5)&&qrCode.isDark(row,col+6)){lostPoint+=40;}}}
132
- for(var col=0;col<moduleCount;col++){for(var row=0;row<moduleCount-6;row++){if(qrCode.isDark(row,col)&&!qrCode.isDark(row+1,col)&&qrCode.isDark(row+2,col)&&qrCode.isDark(row+3,col)&&qrCode.isDark(row+4,col)&&!qrCode.isDark(row+5,col)&&qrCode.isDark(row+6,col)){lostPoint+=40;}}}
133
- var darkCount=0;for(var col=0;col<moduleCount;col++){for(var row=0;row<moduleCount;row++){if(qrCode.isDark(row,col)){darkCount++;}}}
134
- var ratio=Math.abs(100*darkCount/moduleCount/moduleCount-50)/5;lostPoint+=ratio*10;return lostPoint;}};var QRMath={glog:function(n){if(n<1){throw new Error("glog("+n+")");}
135
- return QRMath.LOG_TABLE[n];},gexp:function(n){while(n<0){n+=255;}
136
- while(n>=256){n-=255;}
137
- return QRMath.EXP_TABLE[n];},EXP_TABLE:new Array(256),LOG_TABLE:new Array(256)};for(var i=0;i<8;i++){QRMath.EXP_TABLE[i]=1<<i;}
138
- for(var i=8;i<256;i++){QRMath.EXP_TABLE[i]=QRMath.EXP_TABLE[i-4]^QRMath.EXP_TABLE[i-5]^QRMath.EXP_TABLE[i-6]^QRMath.EXP_TABLE[i-8];}
139
- for(var i=0;i<255;i++){QRMath.LOG_TABLE[QRMath.EXP_TABLE[i]]=i;}
140
- function QRPolynomial(num,shift){if(num.length==undefined){throw new Error(num.length+"/"+shift);}
141
- var offset=0;while(offset<num.length&&num[offset]==0){offset++;}
142
- this.num=new Array(num.length-offset+shift);for(var i=0;i<num.length-offset;i++){this.num[i]=num[i+offset];}}
143
- QRPolynomial.prototype={get:function(index){return this.num[index];},getLength:function(){return this.num.length;},multiply:function(e){var num=new Array(this.getLength()+e.getLength()-1);for(var i=0;i<this.getLength();i++){for(var j=0;j<e.getLength();j++){num[i+j]^=QRMath.gexp(QRMath.glog(this.get(i))+QRMath.glog(e.get(j)));}}
144
- return new QRPolynomial(num,0);},mod:function(e){if(this.getLength()-e.getLength()<0){return this;}
145
- var ratio=QRMath.glog(this.get(0))-QRMath.glog(e.get(0));var num=new Array(this.getLength());for(var i=0;i<this.getLength();i++){num[i]=this.get(i);}
146
- for(var i=0;i<e.getLength();i++){num[i]^=QRMath.gexp(QRMath.glog(e.get(i))+ratio);}
147
- return new QRPolynomial(num,0).mod(e);}};function QRRSBlock(totalCount,dataCount){this.totalCount=totalCount;this.dataCount=dataCount;}
148
- QRRSBlock.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]];QRRSBlock.getRSBlocks=function(typeNumber,errorCorrectLevel){var rsBlock=QRRSBlock.getRsBlockTable(typeNumber,errorCorrectLevel);if(rsBlock==undefined){throw new Error("bad rs block @ typeNumber:"+typeNumber+"/errorCorrectLevel:"+errorCorrectLevel);}
149
- var length=rsBlock.length/3;var list=[];for(var i=0;i<length;i++){var count=rsBlock[i*3+0];var totalCount=rsBlock[i*3+1];var dataCount=rsBlock[i*3+2];for(var j=0;j<count;j++){list.push(new QRRSBlock(totalCount,dataCount));}}
150
- return list;};QRRSBlock.getRsBlockTable=function(typeNumber,errorCorrectLevel){switch(errorCorrectLevel){case QRErrorCorrectLevel.L:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+0];case QRErrorCorrectLevel.M:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+1];case QRErrorCorrectLevel.Q:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+2];case QRErrorCorrectLevel.H:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+3];default:return undefined;}};function QRBitBuffer(){this.buffer=[];this.length=0;}
151
- QRBitBuffer.prototype={get:function(index){var bufIndex=Math.floor(index/8);return((this.buffer[bufIndex]>>>(7-index%8))&1)==1;},put:function(num,length){for(var i=0;i<length;i++){this.putBit(((num>>>(length-i-1))&1)==1);}},getLengthInBits:function(){return this.length;},putBit:function(bit){var bufIndex=Math.floor(this.length/8);if(this.buffer.length<=bufIndex){this.buffer.push(0);}
152
- if(bit){this.buffer[bufIndex]|=(0x80>>>(this.length%8));}
153
- this.length++;}};var QRCodeLimitLength=[[17,14,11,7],[32,26,20,14],[53,42,32,24],[78,62,46,34],[106,84,60,44],[134,106,74,58],[154,122,86,64],[192,152,108,84],[230,180,130,98],[271,213,151,119],[321,251,177,137],[367,287,203,155],[425,331,241,177],[458,362,258,194],[520,412,292,220],[586,450,322,250],[644,504,364,280],[718,560,394,310],[792,624,442,338],[858,666,482,382],[929,711,509,403],[1003,779,565,439],[1091,857,611,461],[1171,911,661,511],[1273,997,715,535],[1367,1059,751,593],[1465,1125,805,625],[1528,1190,868,658],[1628,1264,908,698],[1732,1370,982,742],[1840,1452,1030,790],[1952,1538,1112,842],[2068,1628,1168,898],[2188,1722,1228,958],[2303,1809,1283,983],[2431,1911,1351,1051],[2563,1989,1423,1093],[2699,2099,1499,1139],[2809,2213,1579,1219],[2953,2331,1663,1273]];
154
-
155
- function _isSupportCanvas() {
156
- return typeof CanvasRenderingContext2D != "undefined";
157
- }
158
-
159
- // android 2.x doesn't support Data-URI spec
160
- function _getAndroid() {
161
- var android = false;
162
- var sAgent = navigator.userAgent;
163
-
164
- if (/android/i.test(sAgent)) { // android
165
- android = true;
166
- var aMat = sAgent.toString().match(/android ([0-9]\.[0-9])/i);
167
-
168
- if (aMat && aMat[1]) {
169
- android = parseFloat(aMat[1]);
170
- }
171
- }
172
-
173
- return android;
174
- }
175
-
176
- var svgDrawer = (function() {
177
-
178
- var Drawing = function (el, htOption) {
179
- this._el = el;
180
- this._htOption = htOption;
181
- };
182
-
183
- Drawing.prototype.draw = function (oQRCode) {
184
- var _htOption = this._htOption;
185
- var _el = this._el;
186
- var nCount = oQRCode.getModuleCount();
187
- var nWidth = Math.floor(_htOption.width / nCount);
188
- var nHeight = Math.floor(_htOption.height / nCount);
189
-
190
- this.clear();
191
-
192
- function makeSVG(tag, attrs) {
193
- var el = document.createElementNS('http://www.w3.org/2000/svg', tag);
194
- for (var k in attrs)
195
- if (attrs.hasOwnProperty(k)) el.setAttribute(k, attrs[k]);
196
- return el;
197
- }
198
-
199
- var svg = makeSVG("svg" , {'viewBox': '0 0 ' + String(nCount) + " " + String(nCount), 'width': '100%', 'height': '100%', 'fill': _htOption.colorLight});
200
- svg.setAttributeNS("http://www.w3.org/2000/xmlns/", "xmlns:xlink", "http://www.w3.org/1999/xlink");
201
- _el.appendChild(svg);
202
-
203
- svg.appendChild(makeSVG("rect", {"fill": _htOption.colorLight, "width": "100%", "height": "100%"}));
204
- svg.appendChild(makeSVG("rect", {"fill": _htOption.colorDark, "width": "1", "height": "1", "id": "template"}));
205
-
206
- for (var row = 0; row < nCount; row++) {
207
- for (var col = 0; col < nCount; col++) {
208
- if (oQRCode.isDark(row, col)) {
209
- var child = makeSVG("use", {"x": String(col), "y": String(row)});
210
- child.setAttributeNS("http://www.w3.org/1999/xlink", "href", "#template")
211
- svg.appendChild(child);
212
- }
213
- }
214
- }
215
- };
216
- Drawing.prototype.clear = function () {
217
- while (this._el.hasChildNodes())
218
- this._el.removeChild(this._el.lastChild);
219
- };
220
- return Drawing;
221
- })(window);
222
-
223
- var useSVG = document.documentElement.tagName.toLowerCase() === "svg";
224
-
225
- // Drawing in DOM by using Table tag
226
- var Drawing = useSVG ? svgDrawer : !_isSupportCanvas() ? (function () {
227
- var Drawing = function (el, htOption) {
228
- this._el = el;
229
- this._htOption = htOption;
230
- };
231
-
232
- /**
233
- * Draw the QRCode
234
- *
235
- * @param {QRCode} oQRCode
236
- */
237
- Drawing.prototype.draw = function (oQRCode) {
238
- var _htOption = this._htOption;
239
- var _el = this._el;
240
- var nCount = oQRCode.getModuleCount();
241
- var nWidth = Math.floor(_htOption.width / nCount);
242
- var nHeight = Math.floor(_htOption.height / nCount);
243
- var aHTML = ['<table style="border:0;border-collapse:collapse;">'];
244
-
245
- for (var row = 0; row < nCount; row++) {
246
- aHTML.push('<tr>');
247
-
248
- for (var col = 0; col < nCount; col++) {
249
- aHTML.push('<td style="border:0;border-collapse:collapse;padding:0;margin:0;width:' + nWidth + 'px;height:' + nHeight + 'px;background-color:' + (oQRCode.isDark(row, col) ? _htOption.colorDark : _htOption.colorLight) + ';"></td>');
250
- }
251
-
252
- aHTML.push('</tr>');
253
- }
254
-
255
- aHTML.push('</table>');
256
- _el.innerHTML = aHTML.join('');
257
-
258
- // Fix the margin values as real size.
259
- var elTable = _el.childNodes[0];
260
- var nLeftMarginTable = (_htOption.width - elTable.offsetWidth) / 2;
261
- var nTopMarginTable = (_htOption.height - elTable.offsetHeight) / 2;
262
-
263
- if (nLeftMarginTable > 0 && nTopMarginTable > 0) {
264
- elTable.style.margin = nTopMarginTable + "px " + nLeftMarginTable + "px";
265
- }
266
- };
267
-
268
- /**
269
- * Clear the QRCode
270
- */
271
- Drawing.prototype.clear = function () {
272
- this._el.innerHTML = '';
273
- };
274
-
275
- return Drawing;
276
- })(window) : (function () { // Drawing in Canvas
277
- function _onMakeImage() {
278
- this._elImage.src = this._elCanvas.toDataURL("image/png");
279
- this._elImage.style.display = "block";
280
- this._elCanvas.style.display = "none";
281
- }
282
-
283
- // Android 2.1 bug workaround
284
- // http://code.google.com/p/android/issues/detail?id=5141
285
- if (this && this._android && this._android <= 2.1) {
286
- var factor = 1 / window.devicePixelRatio;
287
- var drawImage = CanvasRenderingContext2D.prototype.drawImage;
288
- CanvasRenderingContext2D.prototype.drawImage = function (image, sx, sy, sw, sh, dx, dy, dw, dh) {
289
- if (("nodeName" in image) && /img/i.test(image.nodeName)) {
290
- for (var i = arguments.length - 1; i >= 1; i--) {
291
- arguments[i] = arguments[i] * factor;
292
- }
293
- } else if (typeof dw == "undefined") {
294
- arguments[1] *= factor;
295
- arguments[2] *= factor;
296
- arguments[3] *= factor;
297
- arguments[4] *= factor;
298
- }
299
-
300
- drawImage.apply(this, arguments);
301
- };
302
- }
303
-
304
- /**
305
- * Check whether the user's browser supports Data URI or not
306
- *
307
- * @private
308
- * @param {Function} fSuccess Occurs if it supports Data URI
309
- * @param {Function} fFail Occurs if it doesn't support Data URI
310
- */
311
- function _safeSetDataURI(fSuccess, fFail) {
312
- var self = this;
313
- self._fFail = fFail;
314
- self._fSuccess = fSuccess;
315
-
316
- // Check it just once
317
- if (self._bSupportDataURI === null) {
318
- var el = document.createElement("img");
319
- var fOnError = function() {
320
- self._bSupportDataURI = false;
321
-
322
- if (self._fFail) {
323
- self._fFail.call(self);
324
- }
325
- };
326
- var fOnSuccess = function() {
327
- self._bSupportDataURI = true;
328
-
329
- if (self._fSuccess) {
330
- self._fSuccess.call(self);
331
- }
332
- };
333
-
334
- el.onabort = fOnError;
335
- el.onerror = fOnError;
336
- el.onload = fOnSuccess;
337
- el.src = ""; // the Image contains 1px data.
338
- return;
339
- } else if (self._bSupportDataURI === true && self._fSuccess) {
340
- self._fSuccess.call(self);
341
- } else if (self._bSupportDataURI === false && self._fFail) {
342
- self._fFail.call(self);
343
- }
344
- };
345
-
346
- /**
347
- * Drawing QRCode by using canvas
348
- *
349
- * @constructor
350
- * @param {HTMLElement} el
351
- * @param {Object} htOption QRCode Options
352
- */
353
- var Drawing = function (el, htOption) {
354
- this._bIsPainted = false;
355
- this._android = _getAndroid();
356
-
357
- this._htOption = htOption;
358
- this._elCanvas = document.createElement("canvas");
359
- this._elCanvas.width = htOption.width;
360
- this._elCanvas.height = htOption.height;
361
- el.appendChild(this._elCanvas);
362
- this._el = el;
363
- this._oContext = this._elCanvas.getContext("2d");
364
- this._bIsPainted = false;
365
- this._elImage = document.createElement("img");
366
- this._elImage.alt = "Scan me!";
367
- this._elImage.style.display = "none";
368
- this._el.appendChild(this._elImage);
369
- this._bSupportDataURI = null;
370
- };
371
-
372
- /**
373
- * Draw the QRCode
374
- *
375
- * @param {QRCode} oQRCode
376
- */
377
- Drawing.prototype.draw = function (oQRCode) {
378
- var _elImage = this._elImage;
379
- var _oContext = this._oContext;
380
- var _htOption = this._htOption;
381
-
382
- var nCount = oQRCode.getModuleCount();
383
- var nWidth = _htOption.width / nCount;
384
- var nHeight = _htOption.height / nCount;
385
- var nRoundedWidth = Math.round(nWidth);
386
- var nRoundedHeight = Math.round(nHeight);
387
-
388
- _elImage.style.display = "none";
389
- this.clear();
390
-
391
- for (var row = 0; row < nCount; row++) {
392
- for (var col = 0; col < nCount; col++) {
393
- var bIsDark = oQRCode.isDark(row, col);
394
- var nLeft = col * nWidth;
395
- var nTop = row * nHeight;
396
- _oContext.strokeStyle = bIsDark ? _htOption.colorDark : _htOption.colorLight;
397
- _oContext.lineWidth = 1;
398
- _oContext.fillStyle = bIsDark ? _htOption.colorDark : _htOption.colorLight;
399
- _oContext.fillRect(nLeft, nTop, nWidth, nHeight);
400
-
401
- // 안티 앨리어싱 방지 처리
402
- _oContext.strokeRect(
403
- Math.floor(nLeft) + 0.5,
404
- Math.floor(nTop) + 0.5,
405
- nRoundedWidth,
406
- nRoundedHeight
407
- );
408
-
409
- _oContext.strokeRect(
410
- Math.ceil(nLeft) - 0.5,
411
- Math.ceil(nTop) - 0.5,
412
- nRoundedWidth,
413
- nRoundedHeight
414
- );
415
- }
416
- }
417
-
418
- this._bIsPainted = true;
419
- };
420
-
421
- /**
422
- * Make the image from Canvas if the browser supports Data URI.
423
- */
424
- Drawing.prototype.makeImage = function () {
425
- if (this._bIsPainted) {
426
- _safeSetDataURI.call(this, _onMakeImage);
427
- }
428
- };
429
-
430
- /**
431
- * Return whether the QRCode is painted or not
432
- *
433
- * @return {Boolean}
434
- */
435
- Drawing.prototype.isPainted = function () {
436
- return this._bIsPainted;
437
- };
438
-
439
- /**
440
- * Clear the QRCode
441
- */
442
- Drawing.prototype.clear = function () {
443
- this._oContext.clearRect(0, 0, this._elCanvas.width, this._elCanvas.height);
444
- this._bIsPainted = false;
445
- };
446
-
447
- /**
448
- * @private
449
- * @param {Number} nNumber
450
- */
451
- Drawing.prototype.round = function (nNumber) {
452
- if (!nNumber) {
453
- return nNumber;
454
- }
455
-
456
- return Math.floor(nNumber * 1000) / 1000;
457
- };
458
-
459
- return Drawing;
460
- })(window);
461
-
462
- /**
463
- * Get the type by string length
464
- *
465
- * @private
466
- * @param {String} sText
467
- * @param {Number} nCorrectLevel
468
- * @return {Number} type
469
- */
470
- function _getTypeNumber(sText, nCorrectLevel) {
471
- var nType = 1;
472
- var length = _getUTF8Length(sText);
473
-
474
- for (var i = 0, len = QRCodeLimitLength.length; i <= len; i++) {
475
- var nLimit = 0;
476
-
477
- switch (nCorrectLevel) {
478
- case QRErrorCorrectLevel.L :
479
- nLimit = QRCodeLimitLength[i][0];
480
- break;
481
- case QRErrorCorrectLevel.M :
482
- nLimit = QRCodeLimitLength[i][1];
483
- break;
484
- case QRErrorCorrectLevel.Q :
485
- nLimit = QRCodeLimitLength[i][2];
486
- break;
487
- case QRErrorCorrectLevel.H :
488
- nLimit = QRCodeLimitLength[i][3];
489
- break;
490
- }
491
-
492
- if (length <= nLimit) {
493
- break;
494
- } else {
495
- nType++;
496
- }
497
- }
498
-
499
- if (nType > QRCodeLimitLength.length) {
500
- throw new Error("Too long data");
501
- }
502
-
503
- return nType;
504
- }
505
-
506
- function _getUTF8Length(sText) {
507
- var replacedText = encodeURI(sText).toString().replace(/\%[0-9a-fA-F]{2}/g, 'a');
508
- return replacedText.length + (replacedText.length != sText ? 3 : 0);
509
- }
510
-
511
- /**
512
- * @class QRCode
513
- * @constructor
514
- * @example
515
- * new QRCode(document.getElementById("test"), "http://jindo.dev.naver.com/collie");
516
- *
517
- * @example
518
- * var oQRCode = new QRCode("test", {
519
- * text : "http://naver.com",
520
- * width : 128,
521
- * height : 128
522
- * });
523
- *
524
- * oQRCode.clear(); // Clear the QRCode.
525
- * oQRCode.makeCode("http://map.naver.com"); // Re-create the QRCode.
526
- *
527
- * @param {HTMLElement|String} el target element or 'id' attribute of element.
528
- * @param {Object|String} vOption
529
- * @param {String} vOption.text QRCode link data
530
- * @param {Number} [vOption.width=256]
531
- * @param {Number} [vOption.height=256]
532
- * @param {String} [vOption.colorDark="#000000"]
533
- * @param {String} [vOption.colorLight="#ffffff"]
534
- * @param {QRCode.CorrectLevel} [vOption.correctLevel=QRCode.CorrectLevel.H] [L|M|Q|H]
535
- */
536
- var QRCode = function (el, vOption) {
537
- this._htOption = {
538
- width : 256,
539
- height : 256,
540
- typeNumber : 4,
541
- colorDark : "#000000",
542
- colorLight : "#ffffff",
543
- correctLevel : QRErrorCorrectLevel.H
544
- };
545
-
546
- if (typeof vOption === 'string') {
547
- vOption = {
548
- text : vOption
549
- };
550
- }
551
-
552
- // Overwrites options
553
- if (vOption) {
554
- for (var i in vOption) {
555
- this._htOption[i] = vOption[i];
556
- }
557
- }
558
-
559
- if (typeof el == "string") {
560
- el = document.getElementById(el);
561
- }
562
-
563
- if (this._htOption.useSVG) {
564
- Drawing = svgDrawer;
565
- }
566
-
567
- this._android = _getAndroid();
568
- this._el = el;
569
- this._oQRCode = null;
570
- this._oDrawing = new Drawing(this._el, this._htOption);
571
-
572
- if (this._htOption.text) {
573
- this.makeCode(this._htOption.text);
574
- }
575
- };
576
-
577
- /**
578
- * Make the QRCode
579
- *
580
- * @param {String} sText link data
581
- */
582
- QRCode.prototype.makeCode = function (sText) {
583
- this._oQRCode = new QRCodeModel(_getTypeNumber(sText, this._htOption.correctLevel), this._htOption.correctLevel);
584
- this._oQRCode.addData(sText);
585
- this._oQRCode.make();
586
- this._el.title = sText;
587
- this._oDrawing.draw(this._oQRCode);
588
- this.makeImage();
589
- };
590
-
591
- /**
592
- * Make the Image from Canvas element
593
- * - It occurs automatically
594
- * - Android below 3 doesn't support Data-URI spec.
595
- *
596
- * @private
597
- */
598
- QRCode.prototype.makeImage = function () {
599
- if (typeof this._oDrawing.makeImage == "function" && (!this._android || this._android >= 3)) {
600
- this._oDrawing.makeImage();
601
- }
602
- };
603
-
604
- /**
605
- * Clear the QRCode
606
- */
607
- QRCode.prototype.clear = function () {
608
- this._oDrawing.clear();
609
- };
610
-
611
- /**
612
- * @name QRCode.CorrectLevel
613
- */
614
- QRCode.CorrectLevel = QRErrorCorrectLevel;
615
-
616
- window.QRCode = QRCode;
617
- })(window);
1
+ import { Alphanumeric, Byte, Charset, Encoder, Hanzi, Kanji, Numeric } from '@nuintun/qrcode';
2
+
3
+ function hex2rgb (hex) {
4
+ const value = parseInt(hex.slice(1, 7), 16);
5
+
6
+ return [(value >> 16) & 0xff, (value >> 8) & 0xff, value & 0xff];
7
+ }
8
+
9
+ function getHints ({ fnc1, aimIndicator }) {
10
+ switch (fnc1) {
11
+ case 'GS1':
12
+ return { fnc1: ['GS1'] };
13
+ case 'AIM':
14
+ return { fnc1: ['AIM', +aimIndicator] };
15
+ }
16
+ }
17
+
18
+ function chooseBestMode ({ mode, content, charset }) {
19
+ switch (mode) {
20
+ case 'Auto':
21
+ const NUMERIC_RE = /^\d+$/;
22
+ const ALPHANUMERIC_RE = /^[0-9A-Z$%*+-./: ]+$/;
23
+
24
+ if (NUMERIC_RE.test(content)) {
25
+ return new Numeric(content);
26
+ }
27
+
28
+ if (ALPHANUMERIC_RE.test(content)) {
29
+ return new Alphanumeric(content);
30
+ }
31
+
32
+ const hanzi = new Hanzi(content);
33
+
34
+ try {
35
+ hanzi.encode();
36
+
37
+ return hanzi;
38
+ } catch {
39
+ // 跳过错误
40
+ }
41
+
42
+ const kanji = new Kanji(content);
43
+
44
+ try {
45
+ kanji.encode();
46
+
47
+ return kanji;
48
+ } catch {
49
+ // 跳过错误
50
+ }
51
+
52
+ return new Byte(content, Charset[charset]);
53
+ case 'Hanzi':
54
+ return new Hanzi(content);
55
+ case 'Kanji':
56
+ return new Kanji(content);
57
+ case 'Numeric':
58
+ return new Numeric(content);
59
+ case 'Alphanumeric':
60
+ return new Alphanumeric(content);
61
+ default:
62
+ return new Byte(content, Charset[charset]);
63
+ }
64
+ }
65
+
66
+ export default function (data) {
67
+ const { level, version } = data;
68
+
69
+ const encoder = new Encoder({
70
+ level,
71
+ version,
72
+ hints: getHints(data),
73
+ });
74
+
75
+ try {
76
+ const qrcode = encoder.encode(chooseBestMode(data));
77
+ const { moduleSize, quietZone, background, foreground } = data;
78
+ return qrcode.toDataURL(moduleSize, {
79
+ margin: quietZone,
80
+ background: hex2rgb(background),
81
+ foreground: hex2rgb(foreground),
82
+ });
83
+ } catch (error) {
84
+ return "";
85
+ }
86
+ }
package/package.json CHANGED
@@ -1,21 +1,23 @@
1
1
  {
2
2
  "name": "yh-hiprint",
3
- "version": "2.4.2",
3
+ "version": "2.5.1",
4
4
  "description": "Hiprint for Vue3 by NoahLiu in ForceCon in Hunan Changesha",
5
5
  "main": "index.js",
6
6
  "types": "index.d.ts",
7
7
  "scripts": {
8
+ "start": "npm run pub:aliyun && npm run pub:npm",
8
9
  "pub:aliyun": "npm publish --registry https://packages.aliyun.com/60765e0161a945067837bb5f/npm/npm-registry/ --no-git-checks",
9
10
  "pub:npm": "npm publish --registry https://registry.npmjs.org/ --no-git-checks"
10
11
  },
11
12
  "dependencies": {
12
- "jspdf": "2.5.1",
13
+ "@nuintun/qrcode": "^5.0.1",
14
+ "canvg": "4.0.1",
13
15
  "html2canvas": "1.4.1",
14
- "nzh": "1.0.9",
15
- "canvg": "4.0.1"
16
+ "jspdf": "2.5.1",
17
+ "nzh": "1.0.9"
16
18
  },
17
19
  "peerDependencies": {
18
20
  "vue": "^3.0.0"
19
21
  },
20
22
  "author": "Liubin"
21
- }
23
+ }