yh-hiprint 2.4.1 → 2.5.0

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.
@@ -842,8 +842,11 @@ function init() {
842
842
  fontList: [
843
843
  {title: '微软雅黑', value: 'Microsoft YaHei'},
844
844
  {title: '黑体', value: 'STHeitiSC-Light'},
845
+ {title: '思源黑体', value: 'SourceHanSansCN-Normal'},
845
846
  {title: '宋体', value: 'SimSun'},
847
+ {title: '华为楷体', value: 'STKaiti'},
846
848
  {title: 'cursive', value: 'cursive'},
849
+ {title: 'Times New Roman', value: 'Times New Roman'},
847
850
  ],
848
851
  dataMode: 1,
849
852
  history: true,
package/designer.vue CHANGED
@@ -265,14 +265,14 @@
265
265
  </el-dialog>
266
266
  </template>
267
267
  <script setup>
268
- import { onMounted, ref, onActivated, onDeactivated, computed, watch, nextTick } from "vue";
269
- import { hiprint, defaultElementTypeProvider, fontSize, scale, zIndex, panel, usePaper, useScale, useDataSource } from "yh-hiprint";
270
- import { useRoute, onBeforeRouteUpdate } from "vue-router/dist/vue-router";
271
- import { ElMessageBox } from "element-plus";
272
- import axios from "@/libs/api.request";
268
+ import {onMounted, ref, onActivated, onDeactivated, computed, watch, nextTick} from 'vue';
269
+ import {hiprint, defaultElementTypeProvider, fontSize, scale, zIndex, panel, usePaper, useScale, useDataSource} from 'yh-hiprint';
270
+ import {useRoute, onBeforeRouteUpdate} from 'vue-router/dist/vue-router';
271
+ import {ElMessageBox} from 'element-plus';
272
+ import axios from '@/libs/api.request';
273
273
 
274
274
  const route = useRoute();
275
- const { paperType, paperWidth, paperHeight, setPaper } = usePaper();
275
+ const {paperType, paperWidth, paperHeight, setPaper} = usePaper();
276
276
  function setPaperHandler(type) {
277
277
  setPaper(type, () => {
278
278
  hiprintTemplate.value.setPaper(paperWidth.value, paperHeight.value);
@@ -281,23 +281,23 @@ function setPaperHandler(type) {
281
281
 
282
282
  const hiprintTemplate = ref(null);
283
283
  const canvasRef = ref();
284
- const { scaleValue, scalePercentage, canZoomIn, canZoomOut, zoomIn, zoomOut } = useScale(() => {
284
+ const {scaleValue, scalePercentage, canZoomIn, canZoomOut, zoomIn, zoomOut} = useScale(() => {
285
285
  hiprintTemplate.value.zoom(scaleValue.value);
286
286
  canvasRef?.value.update();
287
287
  });
288
288
 
289
289
  const previewShow = ref(false);
290
- const previewHtml = ref("");
290
+ const previewHtml = ref('');
291
291
  async function previewPrint() {
292
292
  let {
293
- data: { list, json },
293
+ data: {list, json},
294
294
  } = await axios.request({
295
295
  url: `/printTemplate/data/${detailData.value.code}`,
296
- method: "post",
297
- type: "json",
296
+ method: 'post',
297
+ type: 'json',
298
298
  data: [
299
299
  {
300
- code: "50101820",
300
+ code: '50101820',
301
301
  },
302
302
  ],
303
303
  });
@@ -323,12 +323,12 @@ async function previewPrint() {
323
323
  } else {
324
324
  list = [];
325
325
  }
326
- previewHtml.value = new hiprint.PrintTemplate({ template: JSON.parse(json) }).getHtml(list)[0].innerHTML;
326
+ previewHtml.value = new hiprint.PrintTemplate({template: JSON.parse(json)}).getHtml(list)[0].innerHTML;
327
327
  previewShow.value = true;
328
328
  } else {
329
329
  ElMessage.warning({
330
- title: "警告",
331
- message: "模板配置不存在,请检查",
330
+ title: '警告',
331
+ message: '模板配置不存在,请检查',
332
332
  });
333
333
  }
334
334
  }
@@ -337,25 +337,25 @@ function saveConfig() {
337
337
  let arr = [].concat(formCode.value);
338
338
  let json = hiprintTemplate.value.getJson();
339
339
  json.panels[0].printElements.forEach((item) => {
340
- if (item.printElementType.type === "table") {
340
+ if (item.printElementType.type === 'table') {
341
341
  arr.push(item.options.field);
342
342
  }
343
343
  });
344
344
 
345
345
  axios
346
346
  .request({
347
- url: "/printTemplate/save",
348
- method: "post",
349
- type: "json",
347
+ url: '/printTemplate/save',
348
+ method: 'post',
349
+ type: 'json',
350
350
  data: {
351
351
  id: detailData.value.id,
352
352
  json: JSON.stringify(json),
353
- dsIds: arr.join(","),
353
+ dsIds: arr.join(','),
354
354
  },
355
355
  })
356
356
  .then((res) => {
357
357
  ElMessage.success({
358
- message: "恭喜模板保存成功",
358
+ message: '恭喜模板保存成功',
359
359
  });
360
360
  });
361
361
  }
@@ -364,7 +364,7 @@ function clearPrint() {
364
364
  hiprintTemplate.value?.clear();
365
365
  }
366
366
 
367
- const { detailData, getDetail, listCode, dataSourceList, listColumns, formCode, formColumns, dataSourceForm, getDataSourceList } = useDataSource(axios);
367
+ const {detailData, getDetail, listCode, dataSourceList, listColumns, formCode, formColumns, dataSourceForm, getDataSourceList} = useDataSource(axios);
368
368
 
369
369
  watch(
370
370
  () => formColumns.value,
@@ -387,15 +387,15 @@ watch(
387
387
  );
388
388
  let currentElementObj = ref(null);
389
389
  let currentElementObjColumns = computed(() => {
390
- if (currentElementObj.value?.printElementType.type === "table") {
391
- return currentElementObj.value.options.columns[0]["columns"] || [];
390
+ if (currentElementObj.value?.printElementType.type === 'table') {
391
+ return currentElementObj.value.options.columns[0]['columns'] || [];
392
392
  } else {
393
393
  return [];
394
394
  }
395
395
  });
396
396
 
397
397
  function tableFieldChange(val) {
398
- currentElementObj.value.updateOption("field", val);
398
+ currentElementObj.value.updateOption('field', val);
399
399
  }
400
400
 
401
401
  function tableColumnCancel() {
@@ -417,11 +417,11 @@ function init() {
417
417
  options: [],
418
418
  },
419
419
  {
420
- name: "样式",
420
+ name: '样式',
421
421
  options: [
422
422
  {
423
- name: "scale",
424
- after: "transform",
423
+ name: 'scale',
424
+ after: 'transform',
425
425
  hidden: false,
426
426
  },
427
427
  ],
@@ -429,16 +429,16 @@ function init() {
429
429
  ],
430
430
  supportOptions: [
431
431
  {
432
- name: "styler",
432
+ name: 'styler',
433
433
  hidden: true,
434
434
  },
435
435
  {
436
- name: "scale",
437
- after: "transform",
436
+ name: 'scale',
437
+ after: 'transform',
438
438
  hidden: false,
439
439
  },
440
440
  {
441
- name: "formatter",
441
+ name: 'formatter',
442
442
  hidden: true,
443
443
  },
444
444
  ],
@@ -447,18 +447,18 @@ function init() {
447
447
  tabs: [
448
448
  {
449
449
  replace: true,
450
- name: "基本",
450
+ name: '基本',
451
451
  options: [
452
452
  {
453
- name: "field",
453
+ name: 'field',
454
454
  hidden: false,
455
455
  },
456
456
  {
457
- name: "src",
457
+ name: 'src',
458
458
  hidden: false,
459
459
  },
460
460
  {
461
- name: "fit",
461
+ name: 'fit',
462
462
  hidden: false,
463
463
  },
464
464
  ],
@@ -466,31 +466,30 @@ function init() {
466
466
  ],
467
467
  },
468
468
  table: {
469
- tabs: [{ options: [{ name: "field", hidden: true }] }],
469
+ tabs: [{options: [{name: 'field', hidden: true}]}],
470
470
  },
471
471
  });
472
472
 
473
- hiprint.PrintElementTypeManager.buildByHtml(hiprintJQuery(".ep-draggable-item"));
474
- hiprintJQuery("#hiprint-printTemplate").empty();
473
+ hiprint.PrintElementTypeManager.buildByHtml(hiprintJQuery('.ep-draggable-item'));
474
+ hiprintJQuery('#hiprint-printTemplate').empty();
475
475
  let template = JSON.parse(detailData.value.json) || panel;
476
476
  hiprintTemplate.value = new hiprint.PrintTemplate({
477
477
  template,
478
478
  onImageChooseClick: (target) => {
479
479
  // 测试 3秒后修改图片地址值
480
480
  setTimeout(() => {
481
- target.refresh("", {
481
+ target.refresh('', {
482
482
  real: true,
483
483
  });
484
484
  }, 3000);
485
485
  },
486
486
  fontList: [
487
- { title: "微软雅黑", value: "Microsoft YaHei" },
488
- { title: "黑体", value: "STHeitiSC-Light" },
489
- { title: "思源黑体", value: "SourceHanSansCN-Normal" },
490
- { title: "王羲之书法体", value: "王羲之书法体" },
491
- { title: "宋体", value: "SimSun" },
492
- { title: "华为楷体", value: "STKaiti" },
493
- { title: "cursive", value: "cursive" },
487
+ {title: '微软雅黑', value: 'Microsoft YaHei'},
488
+ {title: '黑体', value: 'STHeitiSC-Light'},
489
+ {title: '思源黑体', value: 'SourceHanSansCN-Normal'},
490
+ {title: '宋体', value: 'SimSun'},
491
+ {title: 'cursive', value: 'cursive'},
492
+ {title: 'Times New Roman', value: 'Times New Roman'},
494
493
  ],
495
494
  dataMode: 1,
496
495
  history: true,
@@ -501,11 +500,11 @@ function init() {
501
500
  onUpdateError: (e) => {
502
501
  // console.error(e);
503
502
  },
504
- settingContainer: "#PrintElementOptionSetting",
505
- paginationContainer: ".hiprint-printPagination",
503
+ settingContainer: '#PrintElementOptionSetting',
504
+ paginationContainer: '.hiprint-printPagination',
506
505
  });
507
506
 
508
- hiprintTemplate.value.design("#hiprint-printTemplate", { grid: true });
507
+ hiprintTemplate.value.design('#hiprint-printTemplate', {grid: true});
509
508
  scaleValue.value = hiprintTemplate.value.editingPanel.scale || 1;
510
509
  window.ht = hiprintTemplate.value;
511
510
 
@@ -519,7 +518,7 @@ function init() {
519
518
  })
520
519
  );
521
520
  }
522
- hiprintJQuery(".hiprint-designer").on("mousedown", ".hiprint-printElement", (e) => {
521
+ hiprintJQuery('.hiprint-designer').on('mousedown', '.hiprint-printElement', (e) => {
523
522
  let t = e.currentTarget;
524
523
  let pes = hiprintTemplate.value.editingPanel.printElements;
525
524
  let index = pes.map((item) => item.designTarget[0]).indexOf(t);
@@ -533,8 +532,8 @@ function init() {
533
532
  console.log(error.message);
534
533
  clearPrint();
535
534
  hiprintTemplate.value = null;
536
- if (error.message.indexOf("setTemplateId") > -1) {
537
- ElMessageBox.alert("模板有错误,请返回列表手动修改或这清空模板!");
535
+ if (error.message.indexOf('setTemplateId') > -1) {
536
+ ElMessageBox.alert('模板有错误,请返回列表手动修改或这清空模板!');
538
537
  }
539
538
  }
540
539
  }
@@ -550,7 +549,7 @@ async function updateTemplate() {
550
549
  if (detailData.value && detailData.value.json) {
551
550
  let jsonObj = JSON.parse(detailData.value.json);
552
551
  hiprintTemplate.value.update(jsonObj);
553
- let { width, height } = jsonObj.panels[0];
552
+ let {width, height} = jsonObj.panels[0];
554
553
  paperWidth.value = width;
555
554
  paperHeight.value = height;
556
555
  hiprintTemplate.value.setPaper(width, height);
@@ -567,7 +566,7 @@ async function updateTemplate() {
567
566
  paperNumberLeft: 430,
568
567
  paperNumberTop: 5,
569
568
  printElements: [],
570
- watermarkOptions: { content: "", rotate: 25, timestamp: false, format: "YYYY-MM-DD HH:mm" },
569
+ watermarkOptions: {content: '', rotate: 25, timestamp: false, format: 'YYYY-MM-DD HH:mm'},
571
570
  },
572
571
  ],
573
572
  });
@@ -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,18 +1,20 @@
1
1
  {
2
2
  "name": "yh-hiprint",
3
- "version": "2.4.1",
3
+ "version": "2.5.0",
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"