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> <a href="https://blog.ciaochaos.com/" rel="noopener noreferrer" target="_blank">ciaochaos</a> <a href="https://github.com/CPunisher/" rel="noopener noreferrer" target="_blank">CPunisher</a></div> + <div><strong>作者</strong> <a href="https://blog.ciaochaos.com/" rel="noopener noreferrer" target="_blank">ciaochaos</a> <a href="https://github.com/CPunisher/" rel="noopener noreferrer" target="_blank">CPunisher</a> 丨 <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"> </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"> </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"> </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(); }