From cf6b07988fc0106fac1b10c898dcc715ffa78050 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 6 May 2020 15:20:02 +0800
Subject: [PATCH 01/30] =?UTF-8?q?DSJ=20=E6=A0=B7=E5=BC=8F=E8=B0=83?=
 =?UTF-8?q?=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRendererDSJ.js | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/src/components/QrRendererDSJ.js b/src/components/QrRendererDSJ.js
index d64dcc2..3de682c 100644
--- a/src/components/QrRendererDSJ.js
+++ b/src/components/QrRendererDSJ.js
@@ -18,7 +18,8 @@ function listPoint(props) {
     let posType = props.params[2];
     let id = 0;
 
-    if (width2 <= 0) width2 = 80;
+    if (width2 <= 0) width2 = 70;
+    if (width1 <= 0) width1 = 70;
 
     let available = [];
     let ava2 = [];

From b3b68fa8e1d6093069b07953c98bd99f6f6655d9 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 6 May 2020 18:42:14 +0800
Subject: [PATCH 02/30] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E5=9B=BE=E7=89=87?=
 =?UTF-8?q?=E8=83=8C=E6=99=AF=E6=A0=B7=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRendererImage.js | 136 ++++++++++++++++++++++++++++++
 src/components/Qrcode.js          |   3 +-
 src/utils/qrcodeHandler.js        |   9 +-
 3 files changed, 143 insertions(+), 5 deletions(-)
 create mode 100644 src/components/QrRendererImage.js

diff --git a/src/components/QrRendererImage.js b/src/components/QrRendererImage.js
new file mode 100644
index 0000000..2a6c599
--- /dev/null
+++ b/src/components/QrRendererImage.js
@@ -0,0 +1,136 @@
+import React from "react";
+import './Qrcode.css'
+import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
+import {defaultRenderer, rand} from "../utils/util";
+
+function listPoint(props) {
+    if (!props.qrcode) return []
+
+    const qrcode = props.qrcode;
+    const nCount = qrcode.getModuleCount();
+    const typeTable = getTypeTable(qrcode);
+    const pointList = new Array(nCount);
+
+    let type = props.params[0];
+    let size = props.params[1] / 100 / 3;
+    let opacity = props.params[2] / 100;
+    let posType = props.params[3];
+    let id = 0;
+
+    const vw = [3, -3];
+    const vh = [3, -3];
+
+    if (size <= 0) size = 1.0
+
+    pointList.push(<image key={id++} x="0" y="0" width={nCount} height={nCount} href="http://blog.ciaochaos.com/images/Avatar.jpg"/>);
+
+    for (let x = 0; x < nCount; x++) {
+        for (let y = 0; y < nCount; y++) {
+
+            if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) {
+                if (qrcode.isDark(x, y)) {
+                    if (type == 0)
+                        pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
+                    else if (type == 1)
+                        pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
+                } else {
+                    if (type == 0)
+                        pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="white" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
+                    else if (type == 1)
+                        pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="white" cx={x + 0.5} cy={y + 0.5}/>)
+                }
+            }
+            else if (typeTable[x][y] == QRPointType.POS_CENTER) {
+                if (qrcode.isDark(x, y)) {
+                    if (posType == 0) {
+                        pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
+                    } else if (posType == 1) {
+                        pointList.push(<circle key={id++} fill="white" cx={x + 0.5} cy={y + 0.5} r={5} />)
+                        pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
+                        pointList.push(<circle key={id++} fill="none" strokeWidth="1" stroke="black"  cx={x + 0.5} cy={y + 0.5} r={3} />)
+                    } else if (posType == 2) {
+                        pointList.push(<circle key={id++} fill="white" cx={x + 0.5} cy={y + 0.5} r={5} />)
+                        pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + 0.5} r={1.5} />)
+                        pointList.push(<circle key={id++} fill="none" strokeWidth="0.15" strokeDasharray="0.5,0.5" stroke="black"  cx={x + 0.5} cy={y + 0.5} r={3} />)
+                        for (let w = 0; w < vw.length; w++) {
+                            pointList.push(<circle key={id++} fill="black" cx={x + vw[w] + 0.5} cy={y + 0.5} r={0.5} />)
+                        }
+                        for (let h = 0; h < vh.length; h++) {
+                            pointList.push(<circle key={id++} fill="black" cx={x + 0.5} cy={y + vh[h] + 0.5} r={0.5} />)
+                        }
+                    }
+                }
+
+            }
+            else if (typeTable[x][y] == QRPointType.POS_OTHER) {
+                if (qrcode.isDark(x, y)) {
+                    if (posType == 0) {
+                        pointList.push(<rect width={1} height={1} key={id++} fill="black" x={x} y={y}/>);
+                    }
+                } else {
+                    if (posType == 0) {
+                        pointList.push(<rect width={1} height={1} key={id++} fill="white" x={x} y={y}/>);
+                    }
+                }
+
+            }
+            else {
+                if (qrcode.isDark(x, y)) {
+                    if (type == 0)
+                        pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="black" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
+                    else if (type == 1)
+                        pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="black" cx={x + 0.5} cy={y + 0.5}/>)
+                } else {
+                    if (type == 0)
+                        pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="white" x={x + (1 - size)/2} y={y + (1 - size)/2}/>)
+                    else if (type == 1)
+                        pointList.push(<circle opacity={opacity} r={size / 2} key={id++} fill="white" cx={x + 0.5} cy={y + 0.5}/>)
+                }
+
+            }
+        }
+    }
+
+    return pointList;
+}
+
+export default class QrRendererImage extends React.Component {
+    constructor(props) {
+        super(props);
+        if (this.props.setParamInfo) {
+            this.props.setParamInfo([
+                {
+                    key: '信息点样式',
+                    default: 0,
+                    choices: [
+                        "矩形",
+                        "圆形",
+                    ]
+                },
+                {
+                    key: '信息点缩放',
+                    default: 100
+                },
+                {
+                    key: '信息点不透明度',
+                    default: 100,
+                },
+                {
+                    key: '定位点样式',
+                    default: 2,
+                    choices: [
+                        "矩形",
+                        "圆形",
+                        "行星",
+                    ]
+                },
+                ]
+            );
+        }
+    }
+
+    render() {
+        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+    }
+}
+
diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 37b263c..f6b8e0a 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -16,6 +16,7 @@ import QrRendererRandRound from "./QrRendererRandRound";
 import QrRendererBlank from "./QrRendererBlank";
 import QrRendererRandRect from "./QrRendererRandRect";
 import QrRendererDSJ from "./QrRendererDSJ";
+import QrRendererImage from "./QrRendererImage";
 
 const logoStyle = {
     background: `url(${logo})`,
@@ -29,7 +30,7 @@ const styleList = [
     {value: "A3", renderer: QrRendererRandRound},
     {value: "SP — 1", renderer: QrRendererDSJ},
     {value: "SP — 2", renderer: QrRendererRandRect},
-    {value: "C2", renderer: QrRendererBlank},
+    {value: "C1", renderer: QrRendererImage},
     {value: "D1", renderer: QrRendererBlank},
     {value: "D2", renderer: QrRendererBlank},
 ];
diff --git a/src/utils/qrcodeHandler.js b/src/utils/qrcodeHandler.js
index 724924e..3a947b7 100644
--- a/src/utils/qrcodeHandler.js
+++ b/src/utils/qrcodeHandler.js
@@ -62,10 +62,11 @@ export function getTypeTable(qrcode) {
 
     for (let i = 0; i < PD.length; i++) {
         typeTable[PD[i][0]][PD[i][1]] = QRPointType.POS_CENTER
-        for (let r = -3; r <= 3; r++) {
-            for (let c = -3; c <= 3; c++) {
-                if (!(r == 0 && c == 0))
-                    typeTable[PD[i][0] + r][PD[i][1] + c] = QRPointType.POS_OTHER;
+        for (let r = -4; r <= 4; r++) {
+            for (let c = -4; c <= 4; c++) {
+                if (PD[i][0] + r >= 0 && PD[i][0] + r < nCount && PD[i][1] + c >=0 && PD[i][1] + c < nCount)
+                    if (!(r == 0 && c == 0))
+                        typeTable[PD[i][0] + r][PD[i][1] + c] = QRPointType.POS_OTHER;
             }
         }
     }

From 616b1cd5471ef8db217b5915fa43488a59ff21b9 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Wed, 6 May 2020 21:46:50 +0800
Subject: [PATCH 03/30] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E5=9B=BE=E7=89=87?=
 =?UTF-8?q?=E8=83=8C=E6=99=AF=E6=A0=B7=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRendererImage.js    | 5 +++--
 src/components/QrRendererRandRect.js | 2 +-
 2 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/src/components/QrRendererImage.js b/src/components/QrRendererImage.js
index 2a6c599..4338876 100644
--- a/src/components/QrRendererImage.js
+++ b/src/components/QrRendererImage.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -22,7 +22,7 @@ function listPoint(props) {
 
     if (size <= 0) size = 1.0
 
-    pointList.push(<image key={id++} x="0" y="0" width={nCount} height={nCount} href="http://blog.ciaochaos.com/images/Avatar.jpg"/>);
+    pointList.push(<image key={id++} x="0" y="0" width={nCount} height={nCount} xlinkHref={data}/>);
 
     for (let x = 0; x < nCount; x++) {
         for (let y = 0; y < nCount; y++) {
@@ -134,3 +134,4 @@ export default class QrRendererImage extends React.Component {
     }
 }
 
+let data = ""
diff --git a/src/components/QrRendererRandRect.js b/src/components/QrRendererRandRect.js
index 75dfb1d..fcf78fd 100644
--- a/src/components/QrRendererRandRect.js
+++ b/src/components/QrRendererRandRect.js
@@ -1,6 +1,6 @@
 import React from "react";
 import './Qrcode.css'
-import {defaultRenderer, rand, randRGB} from "../utils/util";
+import {defaultRenderer, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []

From f9f5ceb28b1b02a9908ec9ba380a1c4915f87b90 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Fri, 8 May 2020 00:45:24 +0800
Subject: [PATCH 04/30] download data record

---
 .idea/jsLibraryMappings.xml |   7 +++
 package-lock.json           | 119 ++++++++++++++++++++++++++++++++++++
 package.json                |   3 +-
 src/api/db.js               |  37 +++++++++++
 src/utils/downloader.js     |  13 ++--
 5 files changed, 174 insertions(+), 5 deletions(-)
 create mode 100644 .idea/jsLibraryMappings.xml
 create mode 100644 src/api/db.js

diff --git a/.idea/jsLibraryMappings.xml b/.idea/jsLibraryMappings.xml
new file mode 100644
index 0000000..68023dc
--- /dev/null
+++ b/.idea/jsLibraryMappings.xml
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+  <component name="JavaScriptLibraryMappings">
+    <file url="file://$PROJECT_DIR$" libraries="{qrbtf/node_modules}" />
+    <file url="PROJECT" libraries="{qrbtf/node_modules}" />
+  </component>
+</project>
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index 0247657..59ad16a 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1071,6 +1071,22 @@
         "to-fast-properties": "^2.0.0"
       }
     },
+    "@cloudbase/adapter-interface": {
+      "version": "0.4.0",
+      "resolved": "https://registry.npm.taobao.org/@cloudbase/adapter-interface/download/@cloudbase/adapter-interface-0.4.0.tgz",
+      "integrity": "sha1-xXk1tQPnv6zksVHfY6h9xWSumQc="
+    },
+    "@cloudbase/database": {
+      "version": "0.9.11-rc.0",
+      "resolved": "https://registry.npm.taobao.org/@cloudbase/database/download/@cloudbase/database-0.9.11-rc.0.tgz",
+      "integrity": "sha1-ev1zOIzpzmct1bbZTm5XCNmRQ70=",
+      "requires": {
+        "bson": "^4.0.2",
+        "lodash.clonedeep": "4.5.0",
+        "lodash.set": "4.3.2",
+        "lodash.unset": "4.5.2"
+      }
+    },
     "@cnakazawa/watch": {
       "version": "1.0.4",
       "resolved": "https://registry.npm.taobao.org/@cnakazawa/watch/download/@cnakazawa/watch-1.0.4.tgz",
@@ -2384,6 +2400,37 @@
       "resolved": "https://registry.npm.taobao.org/aws4/download/aws4-1.9.1.tgz?cache=0&sync_timestamp=1578959055063&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faws4%2Fdownload%2Faws4-1.9.1.tgz",
       "integrity": "sha1-fjPY99RJs/ZzzXLeuavcVS2+Uo4="
     },
+    "axios": {
+      "version": "0.19.2",
+      "resolved": "https://registry.npm.taobao.org/axios/download/axios-0.19.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Faxios%2Fdownload%2Faxios-0.19.2.tgz",
+      "integrity": "sha1-PqNsXYgY0NX4qKl6bTa4bNwAyyc=",
+      "requires": {
+        "follow-redirects": "1.5.10"
+      },
+      "dependencies": {
+        "debug": {
+          "version": "3.1.0",
+          "resolved": "https://registry.npm.taobao.org/debug/download/debug-3.1.0.tgz",
+          "integrity": "sha1-W7WgZyYotkFJVmuhaBnmFRjGcmE=",
+          "requires": {
+            "ms": "2.0.0"
+          }
+        },
+        "follow-redirects": {
+          "version": "1.5.10",
+          "resolved": "https://registry.npm.taobao.org/follow-redirects/download/follow-redirects-1.5.10.tgz?cache=0&sync_timestamp=1585479417937&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Ffollow-redirects%2Fdownload%2Ffollow-redirects-1.5.10.tgz",
+          "integrity": "sha1-e3qfmuov3/NnhqlP9kPtB/T/Xio=",
+          "requires": {
+            "debug": "=3.1.0"
+          }
+        },
+        "ms": {
+          "version": "2.0.0",
+          "resolved": "https://registry.npm.taobao.org/ms/download/ms-2.0.0.tgz",
+          "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
+        }
+      }
+    },
     "axobject-query": {
       "version": "2.1.2",
       "resolved": "https://registry.npm.taobao.org/axobject-query/download/axobject-query-2.1.2.tgz",
@@ -3099,6 +3146,26 @@
         "node-int64": "^0.4.0"
       }
     },
+    "bson": {
+      "version": "4.0.4",
+      "resolved": "https://registry.npm.taobao.org/bson/download/bson-4.0.4.tgz",
+      "integrity": "sha1-S9os7fKuehjRXLJO4e3ox5f47s8=",
+      "requires": {
+        "buffer": "^5.1.0",
+        "long": "^4.0.0"
+      },
+      "dependencies": {
+        "buffer": {
+          "version": "5.6.0",
+          "resolved": "https://registry.npm.taobao.org/buffer/download/buffer-5.6.0.tgz?cache=0&sync_timestamp=1588706716358&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbuffer%2Fdownload%2Fbuffer-5.6.0.tgz",
+          "integrity": "sha1-oxdJ3H2B2E2wir+Te2uMQDP2J4Y=",
+          "requires": {
+            "base64-js": "^1.0.2",
+            "ieee754": "^1.1.4"
+          }
+        }
+      }
+    },
     "buffer": {
       "version": "4.9.2",
       "resolved": "https://registry.npm.taobao.org/buffer/download/buffer-4.9.2.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fbuffer%2Fdownload%2Fbuffer-4.9.2.tgz",
@@ -3452,6 +3519,14 @@
         "shallow-clone": "^0.1.2"
       }
     },
+    "cloudbase-adapter-wx_mp": {
+      "version": "0.1.1",
+      "resolved": "https://registry.npm.taobao.org/cloudbase-adapter-wx_mp/download/cloudbase-adapter-wx_mp-0.1.1.tgz",
+      "integrity": "sha1-J1DtgUX4IWhB0lu7XWubSiFLhDg=",
+      "requires": {
+        "@cloudbase/adapter-interface": "^0.4.0"
+      }
+    },
     "co": {
       "version": "4.6.0",
       "resolved": "https://registry.npm.taobao.org/co/download/co-4.6.0.tgz",
@@ -3812,6 +3887,11 @@
         "randomfill": "^1.0.3"
       }
     },
+    "crypto-js": {
+      "version": "3.3.0",
+      "resolved": "https://registry.npm.taobao.org/crypto-js/download/crypto-js-3.3.0.tgz?cache=0&sync_timestamp=1581508591511&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fcrypto-js%2Fdownload%2Fcrypto-js-3.3.0.tgz",
+      "integrity": "sha1-hG3RzOL2iqz6FWyFePkmpgm3l2s="
+    },
     "css": {
       "version": "2.2.4",
       "resolved": "https://registry.npm.taobao.org/css/download/css-2.2.4.tgz",
@@ -5565,6 +5645,11 @@
         "locate-path": "^2.0.0"
       }
     },
+    "fingerprintjs2": {
+      "version": "2.1.0",
+      "resolved": "https://registry.npm.taobao.org/fingerprintjs2/download/fingerprintjs2-2.1.0.tgz",
+      "integrity": "sha1-Idw/7ifTsZkFbvjrhz3rzNjgYyM="
+    },
     "flat-cache": {
       "version": "2.0.1",
       "resolved": "https://registry.npm.taobao.org/flat-cache/download/flat-cache-2.0.1.tgz",
@@ -8164,11 +8249,21 @@
       "resolved": "https://registry.npm.taobao.org/lodash._reinterpolate/download/lodash._reinterpolate-3.0.0.tgz",
       "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0="
     },
+    "lodash.clonedeep": {
+      "version": "4.5.0",
+      "resolved": "https://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz",
+      "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8="
+    },
     "lodash.memoize": {
       "version": "4.1.2",
       "resolved": "https://registry.npm.taobao.org/lodash.memoize/download/lodash.memoize-4.1.2.tgz",
       "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4="
     },
+    "lodash.set": {
+      "version": "4.3.2",
+      "resolved": "https://registry.npm.taobao.org/lodash.set/download/lodash.set-4.3.2.tgz",
+      "integrity": "sha1-2HV7HagH3eJIFrDWqEvqGnYjCyM="
+    },
     "lodash.sortby": {
       "version": "4.7.0",
       "resolved": "https://registry.npm.taobao.org/lodash.sortby/download/lodash.sortby-4.7.0.tgz",
@@ -8196,11 +8291,21 @@
       "resolved": "https://registry.npm.taobao.org/lodash.uniq/download/lodash.uniq-4.5.0.tgz",
       "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M="
     },
+    "lodash.unset": {
+      "version": "4.5.2",
+      "resolved": "https://registry.npm.taobao.org/lodash.unset/download/lodash.unset-4.5.2.tgz",
+      "integrity": "sha1-Nw0dPoW3Kn4bDN8tJyEhMG8j5O0="
+    },
     "loglevel": {
       "version": "1.6.8",
       "resolved": "https://registry.npm.taobao.org/loglevel/download/loglevel-1.6.8.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Floglevel%2Fdownload%2Floglevel-1.6.8.tgz",
       "integrity": "sha1-iiX7ddCSIw7NRFcnDYC1TigBEXE="
     },
+    "long": {
+      "version": "4.0.0",
+      "resolved": "https://registry.npm.taobao.org/long/download/long-4.0.0.tgz",
+      "integrity": "sha1-mntxz7fTYaGU6lVSQckvdGjVvyg="
+    },
     "loose-envify": {
       "version": "1.4.0",
       "resolved": "https://registry.npm.taobao.org/loose-envify/download/loose-envify-1.4.0.tgz",
@@ -12569,6 +12674,20 @@
       "resolved": "https://registry.npm.taobao.org/tapable/download/tapable-1.1.3.tgz",
       "integrity": "sha1-ofzMBrWNth/XpF2i2kT186Pme6I="
     },
+    "tcb-js-sdk": {
+      "version": "1.6.1",
+      "resolved": "https://registry.npm.taobao.org/tcb-js-sdk/download/tcb-js-sdk-1.6.1.tgz",
+      "integrity": "sha1-jaLnrtwR+iNYqtrr2YcSg4shFUM=",
+      "requires": {
+        "@cloudbase/adapter-interface": "^0.4.0",
+        "@cloudbase/database": "0.9.11-rc.0",
+        "axios": "^0.19.1",
+        "cloudbase-adapter-wx_mp": "^0.1.0",
+        "crypto-js": "^3.1.9-1",
+        "fingerprintjs2": "^2.1.0",
+        "url": "^0.11.0"
+      }
+    },
     "terser": {
       "version": "4.6.12",
       "resolved": "https://registry.npm.taobao.org/terser/download/terser-4.6.12.tgz?cache=0&sync_timestamp=1587902079221&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fterser%2Fdownload%2Fterser-4.6.12.tgz",
diff --git a/package.json b/package.json
index 750cab4..2b23484 100644
--- a/package.json
+++ b/package.json
@@ -8,7 +8,8 @@
     "@testing-library/user-event": "^7.1.2",
     "react": "^16.13.1",
     "react-dom": "^16.13.1",
-    "react-scripts": "3.4.1"
+    "react-scripts": "3.4.1",
+    "tcb-js-sdk": "^1.6.1"
   },
   "scripts": {
     "start": "react-scripts start",
diff --git a/src/api/db.js b/src/api/db.js
new file mode 100644
index 0000000..765d9ee
--- /dev/null
+++ b/src/api/db.js
@@ -0,0 +1,37 @@
+import * as tcb from 'tcb-js-sdk';
+
+const app = tcb.init({
+    env: 'qrbtf-1d845d'
+});
+const auth = app.auth();
+
+async function login() {
+    await auth.signInAnonymously();
+    const loginState = await auth.getLoginState()
+    console.log(loginState.isAnonymous);
+}
+
+login();
+
+const db = app.database();
+const _ = db.command
+const counter = db.collection('QRCounter');
+
+export function insert(value) {
+    counter.add({
+        value: value,
+        count: 1
+    }).then(res => {
+        console.log(res);
+    })
+}
+
+export function update(value) {
+    counter.where({
+        value: _.eq(value)
+    }).update({
+        count: _.inc(1)
+    }).then(res => {
+        console.log(res)
+    })
+}
diff --git a/src/utils/downloader.js b/src/utils/downloader.js
index b93b078..78af1d1 100644
--- a/src/utils/downloader.js
+++ b/src/utils/downloader.js
@@ -1,3 +1,5 @@
+import {insert, update} from "../api/db";
+
 const svgHead = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n " +
     "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 20010904//EN\" \"http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd\">\n"
 
@@ -5,21 +7,23 @@ export function isChrome() {
     return navigator.userAgent.toLowerCase().indexOf('chrome') > -1;
 }
 
-export function saveSvg(filename, content) {
+export function saveSvg(value, content) {
     let htmlContent = [svgHead + content]
     let bl = new Blob(htmlContent, {type: "image/svg+xml"})
     let a = document.createElement("a")
-    filename = "QRcode_" + filename + ".svg"
+    let filename = "QRcode_" + value + ".svg"
 
     a.href = URL.createObjectURL(bl)
     a.download = filename
     a.hidden = true
     a.click()
+
+    update(value)
 }
 
-export function saveImg(filename, content, width, height) {
+export function saveImg(value, content, width, height) {
     // Finish creating downloadable data
-    filename = "QRcode_" + filename + ".jpg";
+    let filename = "QRcode_" + value + ".jpg";
     const wrap = document.createElement('div');
     wrap.innerHTML = content;
 
@@ -56,6 +60,7 @@ export function saveImg(filename, content, width, height) {
         a.setAttribute('target', 'download')
         a.setAttribute('download', filename);
         a.click();
+        update(value)
     };
 
     img.setAttribute('src', 'data:image/svg+xml;base64,' + btoa(svgData));

From ad43a039aa633679d90602c160b2d7756be0a8b1 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 10:27:49 +0800
Subject: [PATCH 05/30] =?UTF-8?q?=E6=96=B0=E6=A0=B7=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRenderer25D.js   | 102 ++++++++++++++++++++++++++++++
 src/components/QrRendererImage.js |   2 +-
 src/components/Qrcode.js          |   3 +-
 3 files changed, 105 insertions(+), 2 deletions(-)
 create mode 100644 src/components/QrRenderer25D.js

diff --git a/src/components/QrRenderer25D.js b/src/components/QrRenderer25D.js
new file mode 100644
index 0000000..ff56816
--- /dev/null
+++ b/src/components/QrRenderer25D.js
@@ -0,0 +1,102 @@
+import React from "react";
+import './Qrcode.css'
+import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
+import {defaultRenderer, rand} from "../utils/util";
+
+function listPoint(props) {
+    if (!props.qrcode) return []
+
+    const qrcode = props.qrcode;
+    const nCount = qrcode.getModuleCount();
+    const typeTable = getTypeTable(qrcode);
+    const pointList = new Array(nCount);
+
+    let type = props.params[0];
+    let size = props.params[1] / 100;
+    let opacity = props.params[2] / 100;
+    let posType = props.params[3];
+    let id = 0;
+
+    const vw = [3, -3];
+    const vh = [3, -3];
+
+    const X = [-Math.sqrt(3)/2, 1/2];
+    const Y = [ Math.sqrt(3)/2, 1/2];
+    const Z = [0, 0];
+
+    const matrixString = 'matrix(' + String(X[0]) + ', ' + String(X[1]) + ', ' + String(Y[0]) + ', ' + String(Y[1]) + ', ' + String(Z[0]) + ', ' + String(Z[1]) + ')'
+
+
+    if (size <= 0) size = 1.0
+
+    for (let x = 0; x < nCount; x++) {
+        for (let y = 0; y < nCount; y++) {
+            if (qrcode.isDark(x, y) == false) continue;
+            else if (typeTable[x][y] == QRPointType.POS_CENTER) {
+                if (posType == 0) {
+                    pointList.push(<rect width={1} height={1} key={id++} fill="rgb(0,0,0)" x={x} y={y} transform={matrixString}/>);
+                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(225,225,225)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
+                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(240,240,240)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
+                }
+            }
+            else if (typeTable[x][y] == QRPointType.POS_OTHER) {
+                if (posType == 0) {
+                    pointList.push(<rect width={1} height={1} key={id++} fill="rgb(0,0,0)" x={x} y={y} transform={matrixString}/>);
+                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(225,225,225)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
+                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(240,240,240)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
+                }
+            }
+            else {
+                if (type == 0) {
+                    pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="rgb(0,0,0)" x={x + (1 - size)/2} y={y + (1 - size)/2} transform={matrixString}/>);
+                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(210,210,210)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
+                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(235,235,235)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
+                }
+            }
+        }
+    }
+
+    return pointList;
+}
+
+export default class QrRenderer25D extends React.Component {
+    constructor(props) {
+        super(props);
+        if (this.props.setParamInfo) {
+            this.props.setParamInfo([
+                {
+                    key: '信息点样式',
+                    default: 0,
+                    choices: [
+                        "矩形",
+                        "圆形",
+                        "随机"
+                    ]
+                },
+                {
+                    key: '信息点缩放',
+                    default: 100
+                },
+                {
+                    key: '信息点不透明度',
+                    default: 100,
+                },
+                {
+                    key: '定位点样式',
+                    default: 0,
+                    choices: [
+                        "矩形",
+                        "圆形",
+                        "行星",
+                    ]
+                },
+                ]
+            );
+        }
+    }
+
+    render() {
+        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+    }
+}
+
diff --git a/src/components/QrRendererImage.js b/src/components/QrRendererImage.js
index 4338876..c841282 100644
--- a/src/components/QrRendererImage.js
+++ b/src/components/QrRendererImage.js
@@ -117,7 +117,7 @@ export default class QrRendererImage extends React.Component {
                 },
                 {
                     key: '定位点样式',
-                    default: 2,
+                    default: 0,
                     choices: [
                         "矩形",
                         "圆形",
diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index f6b8e0a..77e0d9b 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -16,6 +16,7 @@ import QrRendererRandRound from "./QrRendererRandRound";
 import QrRendererBlank from "./QrRendererBlank";
 import QrRendererRandRect from "./QrRendererRandRect";
 import QrRendererDSJ from "./QrRendererDSJ";
+import QrRenderer25D from "./QrRenderer25D";
 import QrRendererImage from "./QrRendererImage";
 
 const logoStyle = {
@@ -30,8 +31,8 @@ const styleList = [
     {value: "A3", renderer: QrRendererRandRound},
     {value: "SP — 1", renderer: QrRendererDSJ},
     {value: "SP — 2", renderer: QrRendererRandRect},
+    {value: "D1", renderer: QrRenderer25D},
     {value: "C1", renderer: QrRendererImage},
-    {value: "D1", renderer: QrRendererBlank},
     {value: "D2", renderer: QrRendererBlank},
 ];
 

From f235315bc3af2d15d0538290909ea407c8271ed5 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Fri, 8 May 2020 12:47:23 +0800
Subject: [PATCH 06/30] =?UTF-8?q?=E6=96=B0=E6=A0=B7=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRenderer25D.js       | 9 +++++++--
 src/components/QrRendererBase.js      | 9 +++++++--
 src/components/QrRendererBlank.js     | 8 ++++++--
 src/components/QrRendererDSJ.js       | 9 +++++++--
 src/components/QrRendererImage.js     | 9 +++++++--
 src/components/QrRendererRandRect.js  | 9 +++++++--
 src/components/QrRendererRandRound.js | 9 +++++++--
 src/components/QrRendererRound.js     | 9 +++++++--
 src/utils/util.js                     | 8 --------
 9 files changed, 55 insertions(+), 24 deletions(-)

diff --git a/src/components/QrRenderer25D.js b/src/components/QrRenderer25D.js
index ff56816..fd8bfdb 100644
--- a/src/components/QrRenderer25D.js
+++ b/src/components/QrRenderer25D.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer, defaultViewBox, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -96,7 +96,12 @@ export default class QrRenderer25D extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererBase.js b/src/components/QrRendererBase.js
index 34ab950..3c3e103 100644
--- a/src/components/QrRendererBase.js
+++ b/src/components/QrRendererBase.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer, defaultViewBox, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -107,7 +107,12 @@ export default class QrRendererBase extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererBlank.js b/src/components/QrRendererBlank.js
index be3c819..77fce98 100644
--- a/src/components/QrRendererBlank.js
+++ b/src/components/QrRendererBlank.js
@@ -1,10 +1,14 @@
 import React from "react";
 import './Qrcode.css'
-import {defaultRenderer} from "../utils/util";
+import {defaultViewBox} from "../utils/util";
 
 export default class QrRendererBlank extends React.Component {
     render() {
-        return defaultRenderer(this.props.qrcode);
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererDSJ.js b/src/components/QrRendererDSJ.js
index c3f2259..337566f 100644
--- a/src/components/QrRendererDSJ.js
+++ b/src/components/QrRendererDSJ.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer, defaultViewBox, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -186,7 +186,12 @@ export default class QrRendererDSJ extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererImage.js b/src/components/QrRendererImage.js
index c841282..f00195b 100644
--- a/src/components/QrRendererImage.js
+++ b/src/components/QrRendererImage.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer} from "../utils/util";
+import {defaultRenderer, defaultViewBox} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -130,7 +130,12 @@ export default class QrRendererImage extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererRandRect.js b/src/components/QrRendererRandRect.js
index fcf78fd..a6cd774 100644
--- a/src/components/QrRendererRandRect.js
+++ b/src/components/QrRendererRandRect.js
@@ -1,6 +1,6 @@
 import React from "react";
 import './Qrcode.css'
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer, defaultViewBox, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -40,7 +40,12 @@ function listPoint(props) {
 
 export default class QrRendererRandRect extends React.Component {
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererRandRound.js b/src/components/QrRendererRandRound.js
index 109122f..b581b6b 100644
--- a/src/components/QrRendererRandRound.js
+++ b/src/components/QrRendererRandRound.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {rand, defaultRenderer} from "../utils/util";
+import {rand, defaultRenderer, defaultViewBox} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -107,7 +107,12 @@ export default class QrRendererRandRound extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/components/QrRendererRound.js b/src/components/QrRendererRound.js
index cf1762b..d23f7f1 100644
--- a/src/components/QrRendererRound.js
+++ b/src/components/QrRendererRound.js
@@ -1,7 +1,7 @@
 import React from "react";
 import './Qrcode.css'
 import {getTypeTable, QRPointType} from "../utils/qrcodeHandler";
-import {defaultRenderer, rand} from "../utils/util";
+import {defaultRenderer, defaultViewBox, rand} from "../utils/util";
 
 function listPoint(props) {
     if (!props.qrcode) return []
@@ -107,7 +107,12 @@ export default class QrRendererRound extends React.Component {
     }
 
     render() {
-        return defaultRenderer(this.props.qrcode, listPoint(this.props));
+        return (
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+                 xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
+                {listPoint(this.props)}
+            </svg>
+        );
     }
 }
 
diff --git a/src/utils/util.js b/src/utils/util.js
index 5c6ab47..a79d532 100644
--- a/src/utils/util.js
+++ b/src/utils/util.js
@@ -22,14 +22,6 @@ export function defaultViewBox(qrcode) {
     return String(-nCount / 5) + ' ' + String(-nCount / 5) + ' ' + String(nCount + nCount / 5 * 2) + ' ' + String(nCount + nCount / 5 * 2);
 }
 
-export function defaultRenderer(qrcode, points) {
-    return (
-        <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(qrcode)} fill="white"
-             xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
-            {points}
-        </svg>
-    );
-}
 
 export function isWeiXin(){
     const ua = window.navigator.userAgent.toLowerCase();

From f9a58fb4aa07006fb0fc2618d8d46fe350ee2f33 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 14:52:53 +0800
Subject: [PATCH 07/30] =?UTF-8?q?=E6=9B=B4=E6=96=B0=E6=96=B0=E6=A0=B7?=
 =?UTF-8?q?=E5=BC=8F?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRenderer25D.js | 72 ++++++++++++---------------------
 src/components/Qrcode.css       |  3 ++
 2 files changed, 28 insertions(+), 47 deletions(-)

diff --git a/src/components/QrRenderer25D.js b/src/components/QrRenderer25D.js
index fd8bfdb..d8057a2 100644
--- a/src/components/QrRenderer25D.js
+++ b/src/components/QrRenderer25D.js
@@ -11,10 +11,10 @@ function listPoint(props) {
     const typeTable = getTypeTable(qrcode);
     const pointList = new Array(nCount);
 
-    let type = props.params[0];
-    let size = props.params[1] / 100;
-    let opacity = props.params[2] / 100;
-    let posType = props.params[3];
+    let size = 1.03;
+    let size2 = 1.03;
+    let height = props.params[0];
+    let height2 = props.params[1];
     let id = 0;
 
     const vw = [3, -3];
@@ -26,32 +26,21 @@ function listPoint(props) {
 
     const matrixString = 'matrix(' + String(X[0]) + ', ' + String(X[1]) + ', ' + String(Y[0]) + ', ' + String(Y[1]) + ', ' + String(Z[0]) + ', ' + String(Z[1]) + ')'
 
-
-    if (size <= 0) size = 1.0
+    if (height <= 0) height = 1.0;
+    if (height2 <= 0) height2 = 1.0;
 
     for (let x = 0; x < nCount; x++) {
         for (let y = 0; y < nCount; y++) {
             if (qrcode.isDark(x, y) == false) continue;
-            else if (typeTable[x][y] == QRPointType.POS_CENTER) {
-                if (posType == 0) {
-                    pointList.push(<rect width={1} height={1} key={id++} fill="rgb(0,0,0)" x={x} y={y} transform={matrixString}/>);
-                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(225,225,225)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
-                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(240,240,240)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
-                }
-            }
-            else if (typeTable[x][y] == QRPointType.POS_OTHER) {
-                if (posType == 0) {
-                    pointList.push(<rect width={1} height={1} key={id++} fill="rgb(0,0,0)" x={x} y={y} transform={matrixString}/>);
-                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(225,225,225)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
-                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(240,240,240)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
-                }
+            else if (typeTable[x][y] == QRPointType.POS_OTHER || typeTable[x][y] == QRPointType.POS_CENTER) {
+                pointList.push(<rect width={size2} height={size2} key={id++} fill="#FF7F89" x={x + (1 - size2)/2} y={y + (1 - size2)/2} transform={matrixString}/>);
+                pointList.push(<rect width={height2} height={size2} key={id++} fill="#FFEBF3" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size2)/2 + size2)+','+String(y + (1 - size2)/2)+') '+'skewY(45) '}/>);
+                pointList.push(<rect width={size2} height={height2} key={id++} fill="#FFD7D9" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size2)/2)+','+String(y + size2 + (1 - size2)/2)+') '+'skewX(45) '}/>);
             }
             else {
-                if (type == 0) {
-                    pointList.push(<rect opacity={opacity} width={size} height={size} key={id++} fill="rgb(0,0,0)" x={x + (1 - size)/2} y={y + (1 - size)/2} transform={matrixString}/>);
-                    pointList.push(<rect opacity={opacity} width={size/2} height={size} key={id++} fill="rgb(210,210,210)" x={0} y={0} transform={matrixString+'translate('+String(x+1)+','+String(y)+') '+'skewY(45) '}/>);
-                    pointList.push(<rect opacity={opacity} width={size} height={size/2} key={id++} fill="rgb(235,235,235)" x={0} y={0} transform={matrixString+'translate('+String(x)+','+String(y+1)+') '+'skewX(45) '}/>);
-                }
+                pointList.push(<rect width={size} height={size} key={id++} fill="#FF7F89" x={x + (1 - size)/2} y={y + (1 - size)/2} transform={matrixString}/>);
+                pointList.push(<rect width={height} height={size} key={id++} fill="#FFEBF3" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size)/2 + size)+','+String(y + (1 - size)/2)+') '+'skewY(45) '}/>);
+                pointList.push(<rect width={size} height={height} key={id++} fill="#FFD7D9" x={0} y={0} transform={matrixString+'translate('+String(x + (1 - size)/2)+','+String(y + size + (1 - size)/2)+') '+'skewX(45) '}/>);
             }
         }
     }
@@ -59,36 +48,25 @@ function listPoint(props) {
     return pointList;
 }
 
+function viewBox(qrcode) {
+    if (!qrcode) return '0 0 0 0';
+
+    const nCount = qrcode.getModuleCount();
+    return String(-nCount) + ' ' + String(-nCount / 2) + ' ' + String(nCount * 2) + ' ' + String(nCount * 2);
+}
+
 export default class QrRenderer25D extends React.Component {
     constructor(props) {
         super(props);
         if (this.props.setParamInfo) {
             this.props.setParamInfo([
                 {
-                    key: '信息点样式',
-                    default: 0,
-                    choices: [
-                        "矩形",
-                        "圆形",
-                        "随机"
-                    ]
+                    key: '柱体高度',
+                    default: 1
                 },
                 {
-                    key: '信息点缩放',
-                    default: 100
-                },
-                {
-                    key: '信息点不透明度',
-                    default: 100,
-                },
-                {
-                    key: '定位点样式',
-                    default: 0,
-                    choices: [
-                        "矩形",
-                        "圆形",
-                        "行星",
-                    ]
+                    key: '定位点柱体高度',
+                    default: 1,
                 },
                 ]
             );
@@ -97,7 +75,7 @@ export default class QrRenderer25D extends React.Component {
 
     render() {
         return (
-            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={defaultViewBox(this.props.qrcode)} fill="white"
+            <svg className="Qr-item-svg" width="100%" height="100%" viewBox={viewBox(this.props.qrcode)} fill="white"
                  xmlns="http://www.w3.org/2000/svg" xmlnsXlink="http://www.w3.org/1999/xlink">
                 {listPoint(this.props)}
             </svg>
diff --git a/src/components/Qrcode.css b/src/components/Qrcode.css
index c726719..17bb110 100644
--- a/src/components/Qrcode.css
+++ b/src/components/Qrcode.css
@@ -84,6 +84,8 @@
 
 .Qr-item-image {
     /*padding: 23px;*/
+    overflow: auto;
+    display: flex;
     background-color: white;
     width: calc((100vw - 56px) / 2);
     height: calc((100vw - 56px) / 2);
@@ -105,6 +107,7 @@
 }
 
 .Qr-item-image-inner {
+    justify-content: center;
     -webkit-transition-timing-function: ease-in-out;
     -moz-transition-timing-function: ease-in-out;
     transition-timing-function: ease-in-out;

From a9c76d5972c0e90e51e03dc6adcaa5b838d08c7b Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 15:35:08 +0800
Subject: [PATCH 08/30] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=B8=8A=E4=B8=8B?=
 =?UTF-8?q?=E6=BB=91=E5=8A=A8=20bug?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.css | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/src/components/Qrcode.css b/src/components/Qrcode.css
index 17bb110..7e5c9c5 100644
--- a/src/components/Qrcode.css
+++ b/src/components/Qrcode.css
@@ -84,7 +84,7 @@
 
 .Qr-item-image {
     /*padding: 23px;*/
-    overflow: auto;
+    overflow: hidden;
     display: flex;
     background-color: white;
     width: calc((100vw - 56px) / 2);

From 5b9a0fb55e630416f9464af6637b1d8ed841452f Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 15:48:23 +0800
Subject: [PATCH 09/30] =?UTF-8?q?=E8=81=94=E7=B3=BB=E6=96=B9=E5=BC=8F?=
 =?UTF-8?q?=E6=9B=B4=E6=96=B0?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Footer.js |  2 +-
 src/components/Qrcode.js | 10 ++++++----
 2 files changed, 7 insertions(+), 5 deletions(-)

diff --git a/src/components/Footer.js b/src/components/Footer.js
index 69e2ed8..c761d50 100644
--- a/src/components/Footer.js
+++ b/src/components/Footer.js
@@ -8,7 +8,7 @@ class Footer extends React.Component {
         return (
             <div className="Qr-titled">
                 <div className="Qr-Centered Qr-footer note-font">
-                    <div><strong>作者</strong>&emsp;<a href="https://blog.ciaochaos.com/" rel="noopener noreferrer" target="_blank">ciaochaos</a>&emsp;<a href="https://github.com/CPunisher/" rel="noopener noreferrer" target="_blank">CPunisher</a></div>
+                    <div><strong>作者</strong>&emsp;<a href="https://blog.ciaochaos.com/" rel="noopener noreferrer" target="_blank">ciaochaos</a>&emsp;<a href="https://github.com/CPunisher/" rel="noopener noreferrer" target="_blank">CPunisher</a>&ensp;丨&ensp;<a href="https://www.yuque.com/qrbtf/docs/contact" rel="noopener noreferrer" target="_blank">联系我们</a></div>
                     <div className="Gray">Copyright © {currentYear} QRBTF. 保留所有权利。</div>
                     <div className="Gray"><a href="http://www.beian.miit.gov.cn/" rel="noopener noreferrer" target="_blank">浙 ICP 备 19005869 号 </a></div>
                 </div>
diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 77e0d9b..1b6357b 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -246,15 +246,17 @@ class Qrcode extends React.Component {
                     </div>
                     <div className="Qr-Centered btn-row">
                         <div className="div-btn">
-                            <a href="https://www.yuque.com/qrbtf/docs" rel="noopener noreferrer" target="_blank">
-                                <button className="dl-btn">使用手册</button>
-                            </a>
                             <a href="https://www.yuque.com/qrbtf/topics" rel="noopener noreferrer" target="_blank">
                                 <button className="dl-btn">问题反馈</button>
                             </a>
+                            <a href="https://www.yuque.com/qrbtf/docs/dev" rel="noopener noreferrer" target="_blank">
+                            <button className="dl-btn">开发与设计</button>
+                            </a>
                         </div>
                         <div className="div-btn">
-                            <button disabled className="dl-btn">提交样式</button>
+                            <a href="https://www.yuque.com/qrbtf/docs/coop" rel="noopener noreferrer" target="_blank">
+                                <button className="dl-btn">商业合作</button>
+                            </a>
                         </div>
                     </div>
                 </div>

From 5dc5c80460513fa61ed2a293d464ece60da4c763 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Fri, 8 May 2020 16:08:17 +0800
Subject: [PATCH 10/30] download data record

---
 src/api/db.js | 31 ++++++++++++++++++-------------
 1 file changed, 18 insertions(+), 13 deletions(-)

diff --git a/src/api/db.js b/src/api/db.js
index 765d9ee..d617d55 100644
--- a/src/api/db.js
+++ b/src/api/db.js
@@ -17,21 +17,26 @@ const db = app.database();
 const _ = db.command
 const counter = db.collection('QRCounter');
 
-export function insert(value) {
-    counter.add({
-        value: value,
-        count: 1
-    }).then(res => {
-        console.log(res);
-    })
-}
-
 export function update(value) {
     counter.where({
         value: _.eq(value)
-    }).update({
-        count: _.inc(1)
-    }).then(res => {
-        console.log(res)
+    }).get().then(res => {
+        if (res.data.length > 0) {
+            counter.where({
+                value: _.eq(value)
+            }).update({
+                count: _.inc(1)
+            }).then(res => {
+                console.log(res)
+            })
+        }
+        else {
+            counter.add({
+                value: value,
+                count: 1
+            }).then(res => {
+                console.log(res)
+            })
+        }
     })
 }

From e1c472961fc3a7674aea20b035025c623d2be1cb Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 16:40:56 +0800
Subject: [PATCH 11/30] =?UTF-8?q?=E6=B5=8B=E8=AF=95=E7=89=88=E7=9B=B8?=
 =?UTF-8?q?=E5=85=B3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.js | 13 ++++++++-----
 1 file changed, 8 insertions(+), 5 deletions(-)

diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 1b6357b..c451fc7 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -157,7 +157,7 @@ class Qrcode extends React.Component {
                     <div style={logoStyle}>
                         <h1 className="Qr-title">&ensp;</h1>
                     </div>
-                    <p className="Qr-subtitle">参数化二维码生成器</p>
+                    <p className="Qr-subtitle">参数化二维码生成器 <sup>测试版</sup></p>
                     <input
                         className="Qr-input big-input"
                         placeholder="Input your URL here"
@@ -214,7 +214,7 @@ class Qrcode extends React.Component {
                                             }}>
                                             <option value={1}>7%</option>
                                             <option value={0}>15%</option>
-                                            <option value={3}>20%</option>
+                                            <option value={3}>25%</option>
                                             <option value={2}>30%</option>
                                         </select>
                                     </td>
@@ -246,14 +246,17 @@ class Qrcode extends React.Component {
                     </div>
                     <div className="Qr-Centered btn-row">
                         <div className="div-btn">
+                            <a href="https://www.yuque.com/qrbtf/docs/donate" rel="noopener noreferrer" target="_blank">
+                                <button className="dl-btn">打赏 & 赞助</button>
+                            </a>
                             <a href="https://www.yuque.com/qrbtf/topics" rel="noopener noreferrer" target="_blank">
                                 <button className="dl-btn">问题反馈</button>
                             </a>
-                            <a href="https://www.yuque.com/qrbtf/docs/dev" rel="noopener noreferrer" target="_blank">
-                            <button className="dl-btn">开发与设计</button>
-                            </a>
                         </div>
                         <div className="div-btn">
+                            <a href="https://www.yuque.com/qrbtf/docs/dev" rel="noopener noreferrer" target="_blank">
+                                <button className="dl-btn">开发与设计</button>
+                            </a>
                             <a href="https://www.yuque.com/qrbtf/docs/coop" rel="noopener noreferrer" target="_blank">
                                 <button className="dl-btn">商业合作</button>
                             </a>

From e01bbb79fb5d66e69846c20cfdc3d69d4306340e Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 16:42:46 +0800
Subject: [PATCH 12/30] =?UTF-8?q?=E6=B5=8B=E8=AF=95=E7=89=88=E7=9B=B8?=
 =?UTF-8?q?=E5=85=B3?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRenderer25D.js | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/components/QrRenderer25D.js b/src/components/QrRenderer25D.js
index d8057a2..dd29d11 100644
--- a/src/components/QrRenderer25D.js
+++ b/src/components/QrRenderer25D.js
@@ -62,11 +62,11 @@ export default class QrRenderer25D extends React.Component {
             this.props.setParamInfo([
                 {
                     key: '柱体高度',
-                    default: 1
+                    default: 0.5,
                 },
                 {
                     key: '定位点柱体高度',
-                    default: 1,
+                    default: 0.5,
                 },
                 ]
             );

From e3bd0d3190de8160dc2cc45c41b417e41aba45c5 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 16:44:52 +0800
Subject: [PATCH 13/30] =?UTF-8?q?=E6=A0=B7=E5=BC=8F=E5=90=8D=E8=B0=83?=
 =?UTF-8?q?=E6=95=B4?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.js | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index c451fc7..5d08744 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -31,9 +31,9 @@ const styleList = [
     {value: "A3", renderer: QrRendererRandRound},
     {value: "SP — 1", renderer: QrRendererDSJ},
     {value: "SP — 2", renderer: QrRendererRandRect},
-    {value: "D1", renderer: QrRenderer25D},
+    {value: "B1", renderer: QrRenderer25D},
     {value: "C1", renderer: QrRendererImage},
-    {value: "D2", renderer: QrRendererBlank},
+    {value: "D1", renderer: QrRendererBlank},
 ];
 
 

From 417ccd08c83ec16df12cc27a4ef98ac4da785736 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 16:46:40 +0800
Subject: [PATCH 14/30] =?UTF-8?q?=E6=96=87=E5=AD=97=E5=BE=AE=E8=B0=83?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.js | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 5d08744..1334722 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -255,7 +255,7 @@ class Qrcode extends React.Component {
                         </div>
                         <div className="div-btn">
                             <a href="https://www.yuque.com/qrbtf/docs/dev" rel="noopener noreferrer" target="_blank">
-                                <button className="dl-btn">开发与设计</button>
+                                <button className="dl-btn">开发 & 设计</button>
                             </a>
                             <a href="https://www.yuque.com/qrbtf/docs/coop" rel="noopener noreferrer" target="_blank">
                                 <button className="dl-btn">商业合作</button>

From 2ac7b63ba11207e35d1b3738431681cad645013e Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 16:54:21 +0800
Subject: [PATCH 15/30] =?UTF-8?q?=E6=96=87=E5=AD=97=E5=BE=AE=E8=B0=83?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.js | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 1334722..8ca9d28 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -157,7 +157,7 @@ class Qrcode extends React.Component {
                     <div style={logoStyle}>
                         <h1 className="Qr-title">&ensp;</h1>
                     </div>
-                    <p className="Qr-subtitle">参数化二维码生成器 <sup>测试版</sup></p>
+                    <p className="Qr-subtitle">参数化二维码生成器 <sup className="note-font">测试版</sup></p>
                     <input
                         className="Qr-input big-input"
                         placeholder="Input your URL here"

From 1cee37fb9fbc45e13333fce2f5b39ccf1d68f529 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 17:00:44 +0800
Subject: [PATCH 16/30] =?UTF-8?q?=E6=96=87=E5=AD=97=E5=BE=AE=E8=B0=83?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/Qrcode.js | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 8ca9d28..9804cdf 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -157,7 +157,7 @@ class Qrcode extends React.Component {
                     <div style={logoStyle}>
                         <h1 className="Qr-title">&ensp;</h1>
                     </div>
-                    <p className="Qr-subtitle">参数化二维码生成器 <sup className="note-font">测试版</sup></p>
+                    <p className="Qr-subtitle">参数化二维码生成器 <sup className="Gray">测试版</sup></p>
                     <input
                         className="Qr-input big-input"
                         placeholder="Input your URL here"
@@ -255,7 +255,7 @@ class Qrcode extends React.Component {
                         </div>
                         <div className="div-btn">
                             <a href="https://www.yuque.com/qrbtf/docs/dev" rel="noopener noreferrer" target="_blank">
-                                <button className="dl-btn">开发 & 设计</button>
+                                <button className="dl-btn">开发与设计</button>
                             </a>
                             <a href="https://www.yuque.com/qrbtf/docs/coop" rel="noopener noreferrer" target="_blank">
                                 <button className="dl-btn">商业合作</button>

From 425aabde1e79064924079cc7f62e6fe57ff827c2 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 17:33:38 +0800
Subject: [PATCH 17/30] =?UTF-8?q?Google=20Analyst=20=E6=94=AF=E6=8C=81?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 public/index.html | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/public/index.html b/public/index.html
index 6b5bd12..351abc4 100644
--- a/public/index.html
+++ b/public/index.html
@@ -1,6 +1,16 @@
 <!DOCTYPE html>
 <html lang="zh">
   <head>
+    <!-- Global site tag (gtag.js) - Google Analytics -->
+    <script async src="https://www.googletagmanager.com/gtag/js?id=UA-165845289-1"></script>
+    <script>
+      window.dataLayer = window.dataLayer || [];
+      function gtag(){dataLayer.push(arguments);}
+      gtag('js', new Date());
+
+      gtag('config', 'UA-165845289-1');
+    </script>
+
     <meta charset="utf-8" />
     <link rel="icon" href="%PUBLIC_URL%/favicon.ico" />
     <!--<meta name="viewport" content="width=device-width, initial-scale=1" />-->

From 7f578a749eb2693b35528d4853bee7b8b7c3134a Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 17:36:18 +0800
Subject: [PATCH 18/30] =?UTF-8?q?Baidu=20=E6=8F=90=E4=BA=A4=E9=93=BE?=
 =?UTF-8?q?=E6=8E=A5?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 public/index.html | 14 ++++++++++++++
 1 file changed, 14 insertions(+)

diff --git a/public/index.html b/public/index.html
index 351abc4..7d53dfc 100644
--- a/public/index.html
+++ b/public/index.html
@@ -10,6 +10,20 @@
 
       gtag('config', 'UA-165845289-1');
     </script>
+    <script>
+      (function(){
+        var bp = document.createElement('script');
+        var curProtocol = window.location.protocol.split(':')[0];
+        if (curProtocol === 'https') {
+          bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';
+        }
+        else {
+          bp.src = 'http://push.zhanzhang.baidu.com/push.js';
+        }
+        var s = document.getElementsByTagName("script")[0];
+        s.parentNode.insertBefore(bp, s);
+      })();
+    </script>
 
     <meta charset="utf-8" />
     <link rel="icon" href="%PUBLIC_URL%/favicon.ico" />

From 10e2968312afc55efb38e6068e0002171942e549 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 17:42:43 +0800
Subject: [PATCH 19/30] =?UTF-8?q?meta=20=E4=BF=A1=E6=81=AF=E6=9B=B4?=
 =?UTF-8?q?=E6=94=B9?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 public/index.html | 25 +------------------------
 1 file changed, 1 insertion(+), 24 deletions(-)

diff --git a/public/index.html b/public/index.html
index 7d53dfc..8b9691d 100644
--- a/public/index.html
+++ b/public/index.html
@@ -32,37 +32,14 @@
     <meta name="viewport" content="width=device-width, height=device-height, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">    <meta name="theme-color" content="#000000" />
     <meta
       name="description"
-      content="Web site created using create-react-app"
+      content="QRBTF 参数化二维码生成器 Parametric QR Code Generator"
     />
     <link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
-    <!--
-      manifest.json provides metadata used when your web app is installed on a
-      user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/
-    -->
     <link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
-    <!--
-      Notice the use of %PUBLIC_URL% in the tags above.
-      It will be replaced with the URL of the `public` folder during the build.
-      Only files inside the `public` folder can be referenced from the HTML.
-
-      Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" will
-      work correctly both with client-side routing and a non-root public URL.
-      Learn how to configure a non-root public URL by running `npm run build`.
-    -->
     <title>QRBTF 参数化二维码生成器</title>
   </head>
   <body>
     <noscript>You need to enable JavaScript to run this app.</noscript>
     <div id="root"></div>
-    <!--
-      This HTML file is a template.
-      If you open it directly in the browser, you will see an empty page.
-
-      You can add webfonts, meta tags, or analytics to this file.
-      The build step will place the bundled scripts into the <body> tag.
-
-      To begin the development, run `npm start` or `yarn start`.
-      To create a production bundle, use `npm run build` or `yarn build`.
-    -->
   </body>
 </html>

From 1764949de4e9295a7d03250a4d3b96cc40b1e70c Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Fri, 8 May 2020 18:15:14 +0800
Subject: [PATCH 20/30] =?UTF-8?q?25D=20=E6=A0=B7=E5=BC=8F=E5=BE=AE?=
 =?UTF-8?q?=E8=B0=83?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 src/components/QrRenderer25D.js | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/src/components/QrRenderer25D.js b/src/components/QrRenderer25D.js
index dd29d11..ee19afb 100644
--- a/src/components/QrRenderer25D.js
+++ b/src/components/QrRenderer25D.js
@@ -11,8 +11,8 @@ function listPoint(props) {
     const typeTable = getTypeTable(qrcode);
     const pointList = new Array(nCount);
 
-    let size = 1.03;
-    let size2 = 1.03;
+    let size = 1.001;
+    let size2 = 1.001;
     let height = props.params[0];
     let height2 = props.params[1];
     let id = 0;

From f584e4795295aa083b81c5d1e9116ad389cacd0f Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Sat, 9 May 2020 00:34:31 +0800
Subject: [PATCH 21/30] [Record more data]

---
 src/api/db.js            | 28 ++++++++++++++++++------
 src/components/Qrcode.js | 46 ++++++++++++++++++++++++++++++++++------
 src/utils/downloader.js  |  7 +++---
 3 files changed, 65 insertions(+), 16 deletions(-)

diff --git a/src/api/db.js b/src/api/db.js
index d617d55..5479d09 100644
--- a/src/api/db.js
+++ b/src/api/db.js
@@ -15,28 +15,42 @@ login();
 
 const db = app.database();
 const _ = db.command
-const counter = db.collection('QRCounter');
 
-export function update(value) {
-    counter.where({
+export function increaseDownloadData(value, date) {
+    db.collection('QRCounter').where({
         value: _.eq(value)
     }).get().then(res => {
         if (res.data.length > 0) {
-            counter.where({
+            db.collection('QRCounter').where({
                 value: _.eq(value)
             }).update({
-                count: _.inc(1)
+                count: _.inc(1),
+                date: date
             }).then(res => {
                 console.log(res)
             })
         }
         else {
-            counter.add({
+            db.collection('QRCounter').add({
                 value: value,
-                count: 1
+                count: 1,
+                date: date
             }).then(res => {
                 console.log(res)
             })
         }
     })
 }
+
+export function recordDownloadDetail({text, value, type, params, history}) {
+    db.collection('QRDownloadData').add({
+        date: new Date().toString(),
+        text: text,
+        value: value,
+        type: type,
+        params: params,
+        history: history
+    }).then(res => {
+        console.log(res)
+    })
+}
diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js
index 9804cdf..0795dd5 100644
--- a/src/components/Qrcode.js
+++ b/src/components/Qrcode.js
@@ -18,6 +18,7 @@ import QrRendererRandRect from "./QrRendererRandRect";
 import QrRendererDSJ from "./QrRendererDSJ";
 import QrRenderer25D from "./QrRenderer25D";
 import QrRendererImage from "./QrRendererImage";
+import {recordDownloadDetail} from "../api/db";
 
 const logoStyle = {
     background: `url(${logo})`,
@@ -49,7 +50,8 @@ class Qrcode extends React.Component {
             qrcode: null,
             paramInfo: [],
             paramValue: [],
-            correctLevel: 0
+            correctLevel: 0,
+            history: []
         };
         this.paramInfoBuffer = new Array(16).fill(new Array(16));
         this.paramValueBuffer = new Array(16).fill(new Array(16));
@@ -90,15 +92,41 @@ class Qrcode extends React.Component {
     }
 
     downloadSvg = (e) => {
-        const style = styleList[this.state.selectedIndex]
-        const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[this.state.selectedIndex]})
+        const selected = this.state.selectedIndex
+        const style = styleList[selected]
+        const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[selected]})
         saveSvg(style.value, ReactDOMServer.renderToString(el))
+        recordDownloadDetail({
+            text: this.state.text,
+            value: styleList[selected],
+            type: 'svg',
+            params: this.state.paramInfo[selected].map((item, index) => {
+                return {
+                    key: item.key,
+                    value: item.choices ? item.choices[this.state.paramValue[selected][index]] : this.state.paramValue[selected][index]
+                }
+            }),
+            history: this.state.history
+        });
     }
 
     downloadImg = (e) => {
-        const style = styleList[this.state.selectedIndex]
-        const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[this.state.selectedIndex]})
+        const selected = this.state.selectedIndex
+        const style = styleList[selected]
+        const el = React.createElement(style.renderer, {qrcode: this.state.qrcode, params: this.state.paramValue[selected]})
         saveImg(style.value, ReactDOMServer.renderToString(el), 1500, 1500)
+        recordDownloadDetail({
+            text: this.state.text,
+            value: styleList[selected],
+            type: 'jpg',
+            params: this.state.paramInfo[selected].map((item, index) => {
+                return {
+                    key: item.key,
+                    value: item.choices ? item.choices[this.state.paramValue[selected][index]] : this.state.paramValue[selected][index]
+                }
+            }),
+            history: this.state.history
+        });
     }
 
     renderParamEditor = (info, index) => {
@@ -150,6 +178,12 @@ class Qrcode extends React.Component {
         }
     }
 
+    changeStyle = (index) => {
+        const newHistory = this.state.history.slice();
+        newHistory.push(styleList[index].value);
+        this.setState({selectedIndex: index, history: newHistory})
+    }
+
     render() {
         return (
             <div className="Qr-outer">
@@ -187,7 +221,7 @@ class Qrcode extends React.Component {
                                         })}
                                         text={this.state.text}
                                         selected={index == this.state.selectedIndex}
-                                        onSelected={() => this.setState({selectedIndex: index})}
+                                        onSelected={this.changeStyle}
                                     />
                                 })
                             }
diff --git a/src/utils/downloader.js b/src/utils/downloader.js
index 78af1d1..75a0548 100644
--- a/src/utils/downloader.js
+++ b/src/utils/downloader.js
@@ -1,4 +1,4 @@
-import {insert, update} from "../api/db";
+import {increaseDownloadData} from "../api/db";
 
 const svgHead = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n " +
     "<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 20010904//EN\" \"http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd\">\n"
@@ -18,7 +18,7 @@ export function saveSvg(value, content) {
     a.hidden = true
     a.click()
 
-    update(value)
+    increaseDownloadData(value, new Date().toString())
 }
 
 export function saveImg(value, content, width, height) {
@@ -60,8 +60,9 @@ export function saveImg(value, content, width, height) {
         a.setAttribute('target', 'download')
         a.setAttribute('download', filename);
         a.click();
-        update(value)
     };
 
     img.setAttribute('src', 'data:image/svg+xml;base64,' + btoa(svgData));
+
+    increaseDownloadData(value, new Date().toString())
 }

From ce7b38218997e3c0ea060c989b4f153ceff7e93a Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Sat, 9 May 2020 13:09:15 +0800
Subject: [PATCH 22/30] Remove console log

---
 src/api/db.js | 4 ----
 1 file changed, 4 deletions(-)

diff --git a/src/api/db.js b/src/api/db.js
index 5479d09..e8722a0 100644
--- a/src/api/db.js
+++ b/src/api/db.js
@@ -8,7 +8,6 @@ const auth = app.auth();
 async function login() {
     await auth.signInAnonymously();
     const loginState = await auth.getLoginState()
-    console.log(loginState.isAnonymous);
 }
 
 login();
@@ -27,7 +26,6 @@ export function increaseDownloadData(value, date) {
                 count: _.inc(1),
                 date: date
             }).then(res => {
-                console.log(res)
             })
         }
         else {
@@ -36,7 +34,6 @@ export function increaseDownloadData(value, date) {
                 count: 1,
                 date: date
             }).then(res => {
-                console.log(res)
             })
         }
     })
@@ -51,6 +48,5 @@ export function recordDownloadDetail({text, value, type, params, history}) {
         params: params,
         history: history
     }).then(res => {
-        console.log(res)
     })
 }

From 47b5922ea20e1169b708c47a7b2994d9c1e9bc2d Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 13 May 2020 16:50:17 +0800
Subject: [PATCH 23/30] dev-redux Action

---
 .github/workflows/nodejs-dev.yml | 37 ++++++++++++++++++++++++++++++++
 1 file changed, 37 insertions(+)
 create mode 100644 .github/workflows/nodejs-dev.yml

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
new file mode 100644
index 0000000..d50c2ee
--- /dev/null
+++ b/.github/workflows/nodejs-dev.yml
@@ -0,0 +1,37 @@
+name: Continuous Integration #action名称
+on:
+  push:
+    branches:
+      - dev-redux
+
+jobs:
+  build:
+    runs-on: ubuntu-latest
+
+    steps:
+      - name: Checkout master
+        uses: actions/checkout@v2
+        with:
+          ref: master
+
+      - name: Setup node
+        uses: actions/setup-node@v1
+        with:
+          node-version: "12.x"
+
+      - name: Build project
+        run: yarn && yarn build
+        env:
+          CI: false
+
+      - name: Authenticate
+        run: sudo chmod 775 ./build/
+
+      - name: Upload COS
+        uses: ciaochaos/tencent-cos-action@master
+        with:
+          args: delete -r -f / && upload -r build/ /
+          secret_id: ${{ secrets.SECRET_ID }}
+          secret_key: ${{ secrets.SECRET_KEY }}
+          bucket: ${{ secrets.BUCKET_DEV }}
+          region: ap-shanghai

From 1b5ee71fcfc92f0a9263b51d67f86e34d0578019 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 13 May 2020 16:53:52 +0800
Subject: [PATCH 24/30] dev-redux Action 2

---
 .github/workflows/nodejs-dev.yml | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index d50c2ee..6959fe6 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -30,7 +30,7 @@ jobs:
       - name: Upload COS
         uses: ciaochaos/tencent-cos-action@master
         with:
-          args: delete -r -f / && upload -r build/ /
+          args: delete -r -f / && upload -r ./build/ /
           secret_id: ${{ secrets.SECRET_ID }}
           secret_key: ${{ secrets.SECRET_KEY }}
           bucket: ${{ secrets.BUCKET_DEV }}

From 0acb23eca79b48cb5f76311da361011588d819cb Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 13 May 2020 16:58:55 +0800
Subject: [PATCH 25/30] dev-redux Action 3

---
 .github/workflows/nodejs-dev.yml | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index 6959fe6..8c21525 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -25,12 +25,12 @@ jobs:
           CI: false
 
       - name: Authenticate
-        run: sudo chmod 775 ./build/
+        run: sudo chmod 775 ./build/ && ls
 
       - name: Upload COS
         uses: ciaochaos/tencent-cos-action@master
         with:
-          args: delete -r -f / && upload -r ./build/ /
+          args: delete -r -f / && upload -r build/ /
           secret_id: ${{ secrets.SECRET_ID }}
           secret_key: ${{ secrets.SECRET_KEY }}
           bucket: ${{ secrets.BUCKET_DEV }}

From 3ec208d417717886b721ff9e27910af437f63698 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 13 May 2020 17:04:18 +0800
Subject: [PATCH 26/30] dev-redux Action 4

---
 .github/workflows/nodejs-dev.yml | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index 8c21525..b408b9c 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -1,4 +1,4 @@
-name: Continuous Integration #action名称
+name: Continuous Integration Dev #action名称
 on:
   push:
     branches:
@@ -25,7 +25,7 @@ jobs:
           CI: false
 
       - name: Authenticate
-        run: sudo chmod 775 ./build/ && ls
+        run: sudo chmod 775 build/ && ls
 
       - name: Upload COS
         uses: ciaochaos/tencent-cos-action@master

From 971c5b039adb2b300c5261fa301607226f46af01 Mon Sep 17 00:00:00 2001
From: ciaochaos <1272777550@qq.com>
Date: Wed, 13 May 2020 17:07:40 +0800
Subject: [PATCH 27/30] dev-redux Action 5

---
 .github/workflows/nodejs-dev.yml | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index b408b9c..c1971d8 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -25,12 +25,12 @@ jobs:
           CI: false
 
       - name: Authenticate
-        run: sudo chmod 775 build/ && ls
+        run: sudo chmod 775 ./build/ && ls
 
       - name: Upload COS
         uses: ciaochaos/tencent-cos-action@master
         with:
-          args: delete -r -f / && upload -r build/ /
+          args: delete -r -f / && upload -r /build/ /
           secret_id: ${{ secrets.SECRET_ID }}
           secret_key: ${{ secrets.SECRET_KEY }}
           bucket: ${{ secrets.BUCKET_DEV }}

From 99156f9cadebe07ce780637c8f01e922a5a48f05 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Wed, 13 May 2020 17:26:31 +0800
Subject: [PATCH 28/30] Update nodejs-dev.yml

---
 .github/workflows/nodejs-dev.yml | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index c1971d8..e674c4b 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -30,7 +30,7 @@ jobs:
       - name: Upload COS
         uses: ciaochaos/tencent-cos-action@master
         with:
-          args: delete -r -f / && upload -r /build/ /
+          args: delete -r -f / && upload -r ./build/ /
           secret_id: ${{ secrets.SECRET_ID }}
           secret_key: ${{ secrets.SECRET_KEY }}
           bucket: ${{ secrets.BUCKET_DEV }}

From 61352e3e15fc491a5336be43c814f3ba22c6c939 Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Wed, 13 May 2020 17:32:28 +0800
Subject: [PATCH 29/30] Update nodejs-dev.yml

---
 .github/workflows/nodejs-dev.yml | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/.github/workflows/nodejs-dev.yml b/.github/workflows/nodejs-dev.yml
index e674c4b..55ca648 100644
--- a/.github/workflows/nodejs-dev.yml
+++ b/.github/workflows/nodejs-dev.yml
@@ -9,10 +9,10 @@ jobs:
     runs-on: ubuntu-latest
 
     steps:
-      - name: Checkout master
+      - name: Checkout dev-redux
         uses: actions/checkout@v2
         with:
-          ref: master
+          ref: dev-redux
 
       - name: Setup node
         uses: actions/setup-node@v1

From 028b25c992d8078e54e5cb3d5e205b58ff3af7be Mon Sep 17 00:00:00 2001
From: CPunisher <1343316114@qq.com>
Date: Wed, 13 May 2020 17:32:56 +0800
Subject: [PATCH 30/30] Update db.js

---
 src/api/db.js | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/src/api/db.js b/src/api/db.js
index d82a585..4eed67a 100644
--- a/src/api/db.js
+++ b/src/api/db.js
@@ -6,7 +6,7 @@ const app = tcb.init({
 const auth = app.auth();
 
 async function login() {
-    // await auth.signInAnonymously();
+    await auth.signInAnonymously();
     // const loginState = await auth.getLoginState();
 }