diff --git a/package-lock.json b/package-lock.json index 59ad16a..c7d0a6f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1074,12 +1074,14 @@ "@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=" + "integrity": "sha1-xXk1tQPnv6zksVHfY6h9xWSumQc=", + "dev": true }, "@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=", + "dev": true, "requires": { "bson": "^4.0.2", "lodash.clonedeep": "4.5.0", @@ -1140,6 +1142,11 @@ "@hapi/hoek": "^8.3.0" } }, + "@icons/material": { + "version": "0.2.4", + "resolved": "https://registry.npm.taobao.org/@icons/material/download/@icons/material-0.2.4.tgz", + "integrity": "sha1-6QyfcXaLNzbnbX3WeD/Gwq+oi8g=" + }, "@jest/console": { "version": "24.9.0", "resolved": "https://registry.npm.taobao.org/@jest/console/download/@jest/console-24.9.0.tgz", @@ -2404,6 +2411,7 @@ "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=", + "dev": true, "requires": { "follow-redirects": "1.5.10" }, @@ -2412,6 +2420,7 @@ "version": "3.1.0", "resolved": "https://registry.npm.taobao.org/debug/download/debug-3.1.0.tgz", "integrity": "sha1-W7WgZyYotkFJVmuhaBnmFRjGcmE=", + "dev": true, "requires": { "ms": "2.0.0" } @@ -2420,6 +2429,7 @@ "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=", + "dev": true, "requires": { "debug": "=3.1.0" } @@ -2427,7 +2437,8 @@ "ms": { "version": "2.0.0", "resolved": "https://registry.npm.taobao.org/ms/download/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true } } }, @@ -3150,6 +3161,7 @@ "version": "4.0.4", "resolved": "https://registry.npm.taobao.org/bson/download/bson-4.0.4.tgz", "integrity": "sha1-S9os7fKuehjRXLJO4e3ox5f47s8=", + "dev": true, "requires": { "buffer": "^5.1.0", "long": "^4.0.0" @@ -3159,6 +3171,7 @@ "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=", + "dev": true, "requires": { "base64-js": "^1.0.2", "ieee754": "^1.1.4" @@ -3523,6 +3536,7 @@ "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=", + "dev": true, "requires": { "@cloudbase/adapter-interface": "^0.4.0" } @@ -3890,7 +3904,8 @@ "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=" + "integrity": "sha1-hG3RzOL2iqz6FWyFePkmpgm3l2s=", + "dev": true }, "css": { "version": "2.2.4", @@ -5648,7 +5663,8 @@ "fingerprintjs2": { "version": "2.1.0", "resolved": "https://registry.npm.taobao.org/fingerprintjs2/download/fingerprintjs2-2.1.0.tgz", - "integrity": "sha1-Idw/7ifTsZkFbvjrhz3rzNjgYyM=" + "integrity": "sha1-Idw/7ifTsZkFbvjrhz3rzNjgYyM=", + "dev": true }, "flat-cache": { "version": "2.0.1", @@ -6172,6 +6188,14 @@ "minimalistic-crypto-utils": "^1.0.1" } }, + "hoist-non-react-statics": { + "version": "3.3.2", + "resolved": "https://registry.npm.taobao.org/hoist-non-react-statics/download/hoist-non-react-statics-3.3.2.tgz", + "integrity": "sha1-7OCsr3HWLClpwuxZ/v9CpLGoW0U=", + "requires": { + "react-is": "^16.7.0" + } + }, "hosted-git-info": { "version": "2.8.8", "resolved": "https://registry.npm.taobao.org/hosted-git-info/download/hosted-git-info-2.8.8.tgz", @@ -8252,7 +8276,8 @@ "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=" + "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", + "dev": true }, "lodash.memoize": { "version": "4.1.2", @@ -8262,7 +8287,8 @@ "lodash.set": { "version": "4.3.2", "resolved": "https://registry.npm.taobao.org/lodash.set/download/lodash.set-4.3.2.tgz", - "integrity": "sha1-2HV7HagH3eJIFrDWqEvqGnYjCyM=" + "integrity": "sha1-2HV7HagH3eJIFrDWqEvqGnYjCyM=", + "dev": true }, "lodash.sortby": { "version": "4.7.0", @@ -8294,7 +8320,8 @@ "lodash.unset": { "version": "4.5.2", "resolved": "https://registry.npm.taobao.org/lodash.unset/download/lodash.unset-4.5.2.tgz", - "integrity": "sha1-Nw0dPoW3Kn4bDN8tJyEhMG8j5O0=" + "integrity": "sha1-Nw0dPoW3Kn4bDN8tJyEhMG8j5O0=", + "dev": true }, "loglevel": { "version": "1.6.8", @@ -8304,7 +8331,8 @@ "long": { "version": "4.0.0", "resolved": "https://registry.npm.taobao.org/long/download/long-4.0.0.tgz", - "integrity": "sha1-mntxz7fTYaGU6lVSQckvdGjVvyg=" + "integrity": "sha1-mntxz7fTYaGU6lVSQckvdGjVvyg=", + "dev": true }, "loose-envify": { "version": "1.4.0", @@ -8392,6 +8420,11 @@ "object-visit": "^1.0.0" } }, + "material-colors": { + "version": "1.2.6", + "resolved": "https://registry.npm.taobao.org/material-colors/download/material-colors-1.2.6.tgz", + "integrity": "sha1-bRlYhxEmmSzuzHL0vMTY8BCGX0Y=" + }, "md5.js": { "version": "1.3.5", "resolved": "https://registry.npm.taobao.org/md5.js/download/md5.js-1.3.5.tgz", @@ -10768,6 +10801,19 @@ } } }, + "react-color": { + "version": "2.18.1", + "resolved": "https://registry.npm.taobao.org/react-color/download/react-color-2.18.1.tgz?cache=0&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Freact-color%2Fdownload%2Freact-color-2.18.1.tgz", + "integrity": "sha1-LNqMyOBqnixSrTkaMN2tMZckcvQ=", + "requires": { + "@icons/material": "^0.2.4", + "lodash": "^4.17.11", + "material-colors": "^1.2.1", + "prop-types": "^15.5.10", + "reactcss": "^1.2.0", + "tinycolor2": "^1.4.1" + } + }, "react-dev-utils": { "version": "10.2.1", "resolved": "https://registry.npm.taobao.org/react-dev-utils/download/react-dev-utils-10.2.1.tgz?cache=0&sync_timestamp=1584750310214&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Freact-dev-utils%2Fdownload%2Freact-dev-utils-10.2.1.tgz", @@ -11022,6 +11068,18 @@ "resolved": "https://registry.npm.taobao.org/react-is/download/react-is-16.13.1.tgz", "integrity": "sha1-eJcppNw23imZ3BVt1sHZwYzqVqQ=" }, + "react-redux": { + "version": "7.2.0", + "resolved": "https://registry.npm.taobao.org/react-redux/download/react-redux-7.2.0.tgz", + "integrity": "sha1-+XD2IZKzmBZC/sRv0NsYoHT+h50=", + "requires": { + "@babel/runtime": "^7.5.5", + "hoist-non-react-statics": "^3.3.0", + "loose-envify": "^1.4.0", + "prop-types": "^15.7.2", + "react-is": "^16.9.0" + } + }, "react-scripts": { "version": "3.4.1", "resolved": "https://registry.npm.taobao.org/react-scripts/download/react-scripts-3.4.1.tgz", @@ -11082,6 +11140,14 @@ "workbox-webpack-plugin": "4.3.1" } }, + "reactcss": { + "version": "1.2.3", + "resolved": "https://registry.npm.taobao.org/reactcss/download/reactcss-1.2.3.tgz", + "integrity": "sha1-wAATh15Vexzw39mjaKHD2rO1SN0=", + "requires": { + "lodash": "^4.0.1" + } + }, "read-pkg": { "version": "3.0.0", "resolved": "https://registry.npm.taobao.org/read-pkg/download/read-pkg-3.0.0.tgz", @@ -11184,6 +11250,36 @@ "strip-indent": "^3.0.0" } }, + "redux": { + "version": "4.0.5", + "resolved": "https://registry.npm.taobao.org/redux/download/redux-4.0.5.tgz?cache=0&sync_timestamp=1577154206919&other_urls=https%3A%2F%2Fregistry.npm.taobao.org%2Fredux%2Fdownload%2Fredux-4.0.5.tgz", + "integrity": "sha1-TbXeWBbheJHeioDEJCMtBvBR2T8=", + "requires": { + "loose-envify": "^1.4.0", + "symbol-observable": "^1.2.0" + } + }, + "redux-devtools": { + "version": "3.5.0", + "resolved": "https://registry.npm.taobao.org/redux-devtools/download/redux-devtools-3.5.0.tgz", + "integrity": "sha1-1pq3bU8Pir320kvPWVTXoaoraCc=", + "dev": true, + "requires": { + "lodash": "^4.2.0", + "prop-types": "^15.5.7", + "redux-devtools-instrument": "^1.9.0" + } + }, + "redux-devtools-instrument": { + "version": "1.9.6", + "resolved": "https://registry.npm.taobao.org/redux-devtools-instrument/download/redux-devtools-instrument-1.9.6.tgz", + "integrity": "sha1-a0EllfdLnUjP1OzBPlhbFYjtbn4=", + "dev": true, + "requires": { + "lodash": "^4.2.0", + "symbol-observable": "^1.0.2" + } + }, "regenerate": { "version": "1.4.0", "resolved": "https://registry.npm.taobao.org/regenerate/download/regenerate-1.4.0.tgz", @@ -12631,6 +12727,11 @@ "util.promisify": "~1.0.0" } }, + "symbol-observable": { + "version": "1.2.0", + "resolved": "https://registry.npm.taobao.org/symbol-observable/download/symbol-observable-1.2.0.tgz", + "integrity": "sha1-wiaIrtTqs83C3+rLtWFmBWCgCAQ=" + }, "symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npm.taobao.org/symbol-tree/download/symbol-tree-3.2.4.tgz", @@ -12678,6 +12779,7 @@ "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=", + "dev": true, "requires": { "@cloudbase/adapter-interface": "^0.4.0", "@cloudbase/database": "0.9.11-rc.0", @@ -12884,6 +12986,11 @@ "resolved": "https://registry.npm.taobao.org/timsort/download/timsort-0.3.0.tgz", "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=" }, + "tinycolor2": { + "version": "1.4.1", + "resolved": "https://registry.npm.taobao.org/tinycolor2/download/tinycolor2-1.4.1.tgz", + "integrity": "sha1-9PrTM0R7wLB9TcjpIJ2POaisd+g=" + }, "tmp": { "version": "0.0.33", "resolved": "https://registry.npm.taobao.org/tmp/download/tmp-0.0.33.tgz", diff --git a/package.json b/package.json index 2b23484..0f35c44 100644 --- a/package.json +++ b/package.json @@ -6,10 +6,13 @@ "@testing-library/jest-dom": "^4.2.4", "@testing-library/react": "^9.3.2", "@testing-library/user-event": "^7.1.2", + "prop-types": "^15.7.2", "react": "^16.13.1", + "react-color": "^2.18.1", "react-dom": "^16.13.1", + "react-redux": "^7.2.0", "react-scripts": "3.4.1", - "tcb-js-sdk": "^1.6.1" + "redux": "^4.0.5" }, "scripts": { "start": "react-scripts start", @@ -32,5 +35,9 @@ "last 1 safari version" ] }, - "homepage": "./" + "homepage": "./", + "devDependencies": { + "redux-devtools": "^3.5.0", + "tcb-js-sdk": "^1.6.1" + } } diff --git a/public/index.html b/public/index.html index 8b9691d..6f9e156 100644 --- a/public/index.html +++ b/public/index.html @@ -4,42 +4,66 @@ - + + + + QRBTF 参数化二维码生成器
+ diff --git a/src/App.js b/src/App.js deleted file mode 100644 index e52f668..0000000 --- a/src/App.js +++ /dev/null @@ -1,18 +0,0 @@ -import React from 'react'; -import './App.css'; -import Layout from './containers/Layout' -import Qrcode from "./components/Qrcode"; - -function App() { - return ( -
-
- - - -
-
- ); -} - -export default App; diff --git a/src/App.test.js b/src/App.test.js deleted file mode 100644 index 4db7ebc..0000000 --- a/src/App.test.js +++ /dev/null @@ -1,9 +0,0 @@ -import React from 'react'; -import { render } from '@testing-library/react'; -import App from './App'; - -test('renders learn react link', () => { - const { getByText } = render(); - const linkElement = getByText(/learn react/i); - expect(linkElement).toBeInTheDocument(); -}); diff --git a/src/actions/index.js b/src/actions/index.js new file mode 100644 index 0000000..2e24e3e --- /dev/null +++ b/src/actions/index.js @@ -0,0 +1,26 @@ +import {actionTypes} from "../constant/ActionTypes"; + +export const genQRInfo = text => ({ + type: actionTypes.GENERATE_QR_INFO, + text +}) + +export const changeStyle = (rendererIndex, rendererType, value) => ({ + type: actionTypes.CHANGE_STYLE, + rendererIndex, rendererType, value +}) + +export const changeCorrectLevel = (correctLevel) => ({ + type: actionTypes.CHANGE_CORRECT_LEVEL, + correctLevel +}) + +export const createParam = (paramInfo, paramValue) => ({ + type: actionTypes.CREATE_PARAM, + paramInfo, paramValue +}) + +export const changeParam = (rendererIndex, paramIndex, value) => ({ + type: actionTypes.CHANGE_PARAM, + rendererIndex, paramIndex, value +}) diff --git a/src/api/db.js b/src/api/db.js index e8722a0..57bf57d 100644 --- a/src/api/db.js +++ b/src/api/db.js @@ -7,7 +7,11 @@ const auth = app.auth(); async function login() { await auth.signInAnonymously(); +<<<<<<< HEAD const loginState = await auth.getLoginState() +======= + // const loginState = await auth.getLoginState(); +>>>>>>> 47e31499e13fa4a29b3e69e6551268f3badb67b2 } login(); @@ -15,7 +19,11 @@ login(); const db = app.database(); const _ = db.command +<<<<<<< HEAD export function increaseDownloadData(value, date) { +======= +export function increaseDownloadData(value) { +>>>>>>> 47e31499e13fa4a29b3e69e6551268f3badb67b2 db.collection('QRCounter').where({ value: _.eq(value) }).get().then(res => { @@ -24,7 +32,11 @@ export function increaseDownloadData(value, date) { value: _.eq(value) }).update({ count: _.inc(1), +<<<<<<< HEAD date: date +======= + date: new Date().toString() +>>>>>>> 47e31499e13fa4a29b3e69e6551268f3badb67b2 }).then(res => { }) } @@ -32,7 +44,11 @@ export function increaseDownloadData(value, date) { db.collection('QRCounter').add({ value: value, count: 1, +<<<<<<< HEAD date: date +======= + date: new Date().toString() +>>>>>>> 47e31499e13fa4a29b3e69e6551268f3badb67b2 }).then(res => { }) } diff --git a/src/components/Footer.js b/src/components/Footer.js deleted file mode 100644 index c761d50..0000000 --- a/src/components/Footer.js +++ /dev/null @@ -1,20 +0,0 @@ -import React from "react"; -import './Qrcode.css'; - -const currentYear = new Date().getFullYear(); - -class Footer extends React.Component { - render() { - return ( -
-
-
作者ciaochaosCPunisher 丨 联系我们
-
Copyright © {currentYear} QRBTF. 保留所有权利。
-
浙 ICP 备 19005869 号
-
-
- ); - } -} - -export default Footer diff --git a/src/components/QrItem.js b/src/components/QrItem.js deleted file mode 100644 index 944117a..0000000 --- a/src/components/QrItem.js +++ /dev/null @@ -1,41 +0,0 @@ -import React from "react"; -import './Qrcode.css' - -function calClassName(props) { - if (props.selected === true) return 'Qr-item Qr-item-selected'; - return 'Qr-item'; -} - -export default class QrItem extends React.Component { - - constructor(props) { - super(props); - } - - componentDidMount() { - this.forceUpdate() - } - - handleClick = (e) => { - this.props.onSelected(this.props.index); - } - - shouldComponentUpdate(nextProps, nextState, nextContext) { - return (nextProps.selected || this.props.selected) && (this.props.text == nextProps.text || this.props.text.length == 0) - } - - render() { - return ( -
-
-
- {this.props.renderer} -
-
-
- {this.props.value} -
-
- ); - } -} diff --git a/src/components/QrRendererBlank.js b/src/components/QrRendererBlank.js deleted file mode 100644 index 77fce98..0000000 --- a/src/components/QrRendererBlank.js +++ /dev/null @@ -1,14 +0,0 @@ -import React from "react"; -import './Qrcode.css' -import {defaultViewBox} from "../utils/util"; - -export default class QrRendererBlank extends React.Component { - render() { - return ( - - - ); - } -} - diff --git a/src/components/QrRendererRandRound.js b/src/components/QrRendererRandRound.js deleted file mode 100644 index b581b6b..0000000 --- a/src/components/QrRendererRandRound.js +++ /dev/null @@ -1,118 +0,0 @@ -import React from "react"; -import './Qrcode.css' -import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; -import {rand, defaultRenderer, defaultViewBox} 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]; - - 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; - - if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) { - if (type == 0) - pointList.push() - else if (type == 1) - pointList.push() - else if (type == 2) - pointList.push() - } - else if (typeTable[x][y] == QRPointType.POS_CENTER) { - if (posType == 0) { - pointList.push(); - } else if (posType == 1) { - pointList.push() - pointList.push() - } else if (posType == 2) { - pointList.push() - pointList.push() - for (let w = 0; w < vw.length; w++) { - pointList.push() - } - for (let h = 0; h < vh.length; h++) { - pointList.push() - } - } - } - else if (typeTable[x][y] == QRPointType.POS_OTHER) { - if (posType == 0) { - pointList.push(); - } - } - else { - if (type == 0) - pointList.push() - else if (type == 1) - pointList.push() - else if (type == 2) - pointList.push() - } - } - } - - return pointList; -} - -export default class QrRendererRandRound extends React.Component { - constructor(props) { - super(props); - if (this.props.setParamInfo) { - this.props.setParamInfo([ - { - key: '信息点样式', - default: 2, - choices: [ - "矩形", - "圆形", - "随机" - ] - }, - { - key: '信息点缩放', - default: 80 - }, - { - key: '信息点不透明度', - default: 100, - }, - { - key: '定位点样式', - default: 2, - choices: [ - "矩形", - "圆形", - "行星", - ] - }, - ] - ); - } - } - - render() { - return ( - - {listPoint(this.props)} - - ); - } -} - diff --git a/src/components/Qrcode.css b/src/components/Qrcode.css index 7e5c9c5..5520677 100644 --- a/src/components/Qrcode.css +++ b/src/components/Qrcode.css @@ -434,3 +434,7 @@ select:-moz-focusring { color: transparent; text-shadow: 0 0 0 #000; } + +.Qr-color-picker { + width: 200px; +} diff --git a/src/components/Qrcode.js b/src/components/Qrcode.js deleted file mode 100644 index 0795dd5..0000000 --- a/src/components/Qrcode.js +++ /dev/null @@ -1,317 +0,0 @@ -/*eslint-disable*/ - -import React from "react"; -import ReactDOMServer from 'react-dom/server' -import {getQrcodeData} from "../utils/qrcodeHandler"; -import {saveImg, saveSvg} from "../utils/downloader"; -import {isWeiXin} from "../utils/util"; -import './Qrcode.css'; -import logo from '../qrbtf-logo.svg'; - -import Footer from "./Footer"; -import QrItem from "./QrItem"; -import QrRendererBase from "./QrRendererBase"; -import QrRendererRound from "./QrRendererRound"; -import QrRendererRandRound from "./QrRendererRandRound"; -import QrRendererBlank from "./QrRendererBlank"; -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})`, - backgroundRepeat: 'no-repeat', - backgroundPosition: 'left' -}; - -const styleList = [ - {value: "A1", renderer: QrRendererBase}, - {value: "A2", renderer: QrRendererRound}, - {value: "A3", renderer: QrRendererRandRound}, - {value: "SP — 1", renderer: QrRendererDSJ}, - {value: "SP — 2", renderer: QrRendererRandRect}, - {value: "B1", renderer: QrRenderer25D}, - {value: "C1", renderer: QrRendererImage}, - {value: "D1", renderer: QrRendererBlank}, -]; - - -class Qrcode extends React.Component { - paramInfoBuffer; - paramValueBuffer; - constructor(props) { - super(props); - this.state = { - text: '', - selectedIndex: 0, - options: {text: ''}, - qrcode: null, - paramInfo: [], - paramValue: [], - correctLevel: 0, - history: [] - }; - this.paramInfoBuffer = new Array(16).fill(new Array(16)); - this.paramValueBuffer = new Array(16).fill(new Array(16)); - } - - componentDidMount() { - const text = 'https://qrbtf.com/'; - this.setState({ - paramInfo: this.paramInfoBuffer, - paramValue: this.paramValueBuffer, - text: text, - options: {text: text}, - qrcode: getQrcodeData({text: text, correctLevel: this.state.correctLevel}) - }); - } - - setParamInfo = (index) => { - const _this = this; - return function (params) { - _this.paramInfoBuffer[index] = params; - _this.paramValueBuffer[index] = params.map(p => { - return p.default - }); - } - } - - setParamValue = (valueIndex, value) => { - const newValue = this.state.paramValue.slice(); - newValue[this.state.selectedIndex][valueIndex] = value; - this.setState({paramValue: newValue}); - } - - handleCreate = (e) => { - let text = this.state.text - if (text.length <= 0) text = 'https://qrbtf.com/'; - this.setState({text: text, options: {text: text}, qrcode: getQrcodeData({text: text, correctLevel: this.state.correctLevel})}); - if (e) e.target.blur(); - } - - downloadSvg = (e) => { - 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 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) => { - if (info.choices) { - return ( - - ); - } - else { - return ( - this.setParamValue(index, e.target.value)} - onKeyPress={(e) => {if(e.key === 'Enter') {this.setParamValue(index, e.target.value); e.target.blur()}}}/> - ); - } - } - - renderAdjustment = () => { - const target = this.state.paramInfo[this.state.selectedIndex]; - if (target instanceof Array) { - return target.map((info, index) => { - return ( - - {info.key} - {this.renderParamEditor(info, index)} - - ) - }) - } - } - - changeStyle = (index) => { - const newHistory = this.state.history.slice(); - newHistory.push(styleList[index].value); - this.setState({selectedIndex: index, history: newHistory}) - } - - render() { - return ( -
-
-
-

-
-

参数化二维码生成器 测试版

- this.setState({text: e.target.value})} - onBlur={this.handleCreate} - onKeyPress={(e) => {if(e.key === 'Enter') this.handleCreate(e)}} - /> -
-
-
-
Styles
-

点击选择样式

-
-
-
- { - styleList.map((style, index) => { - return - }) - } -
-
-
-
-
-
Parameters
-

参数调整

-
-
-
- - - - - - - {this.renderAdjustment()} - -
容错率 - -
-
-
-
-
-
-
Downloads
-

下载二维码 — {styleList[this.state.selectedIndex].value}

-
-
-
- - -
-
-
- -
- -
-
- ); - } -} - -export default Qrcode; - -window.onload = function(){ - if(isWeiXin()){ - const outer = document.getElementById("wx-message"); - const inner = document.createElement("div"); - inner.className = "note-font"; - inner.id = "wx-message-inner"; - inner.innerHTML = "当前客户端不支持下载,请在浏览器中打开。"; - outer.appendChild(inner); - } -} diff --git a/src/App.css b/src/components/app/App.css similarity index 100% rename from src/App.css rename to src/components/app/App.css diff --git a/src/components/app/App.js b/src/components/app/App.js new file mode 100644 index 0000000..4318bae --- /dev/null +++ b/src/components/app/App.js @@ -0,0 +1,30 @@ +import React from 'react'; +import './App.css'; +import '../Qrcode.css'; +import Footer from "../footer/Footer"; +import Header from "../header/Header"; +import PartMore from "./PartMore"; +import PartParams from "./PartParams"; +import PartDownloadViewer from "../../containers/app/PartDownloadViewer"; +import PartStylesViewer from "../../containers/app/PartStylesViewer"; + +function App() { + return ( +
+
+
+
+
+ + + + +
+
+
+
+
+ ); +} + +export default App; diff --git a/src/components/app/PartDownload.js b/src/components/app/PartDownload.js new file mode 100644 index 0000000..ca86092 --- /dev/null +++ b/src/components/app/PartDownload.js @@ -0,0 +1,32 @@ +import React from 'react'; +import './App.css'; +import DownloadSvg from "../../containers/download/DownloadSvg"; +import DownloadJpg from "../../containers/download/DownloadJpg"; +import {isWeiXin} from "../../utils/util"; + +const WxMessage = () => { + if (isWeiXin()) { + return
当前客户端不支持下载,请在浏览器中打开。
+ } + return null +} + +const PartDownload = ({ value }) => ( +
+
+
Downloads
+

下载二维码 — {value}

+
+
+
+ + +
+
+ +
+
+
+) + +export default PartDownload; diff --git a/src/components/app/PartMore.js b/src/components/app/PartMore.js new file mode 100644 index 0000000..b89b139 --- /dev/null +++ b/src/components/app/PartMore.js @@ -0,0 +1,24 @@ +import React from 'react'; +import './App.css'; +import LinkButton from "../link/LinkButton"; + +const PartMore = () => ( +
+
+
More
+

更多

+
+
+
+ + +
+
+ + +
+
+
+) + +export default PartMore; diff --git a/src/components/app/PartParams.js b/src/components/app/PartParams.js new file mode 100644 index 0000000..3ed0310 --- /dev/null +++ b/src/components/app/PartParams.js @@ -0,0 +1,25 @@ +import React from 'react'; +import './App.css'; +import ParamListViewer from "../../containers/param/ParamListViewer"; +import ParamCorrectLevelViewer from "../../containers/param/ParamCorrectLevelViewer"; + +const PartParams = () => ( +
+
+
Parameters
+

参数调整

+
+
+
+ + + + + +
+
+
+
+) + +export default PartParams; diff --git a/src/components/app/PartStyles.js b/src/components/app/PartStyles.js new file mode 100644 index 0000000..e007dfb --- /dev/null +++ b/src/components/app/PartStyles.js @@ -0,0 +1,23 @@ +import React, {useEffect, useState} from 'react'; +import './App.css'; +import StyleListViewer from "../../containers/style/StyleListViewer"; + +const PartStyles = ({ setParamInfo }) => { + const [loaded, setLoaded] = useState(false); + useEffect(() => { + setLoaded(true); + }, []) + const styleList = React.createElement(StyleListViewer({setParamInfo})) + + return (
+
+
Styles
+

点击选择样式

+
+
+ {styleList} +
+
) +} + +export default PartStyles; diff --git a/src/components/download/DownloadButton.js b/src/components/download/DownloadButton.js new file mode 100644 index 0000000..ce510e9 --- /dev/null +++ b/src/components/download/DownloadButton.js @@ -0,0 +1,16 @@ +import React from "react"; +import PropTypes from 'prop-types' +import '../Qrcode.css'; + +const DownloadButton = ({ onClick, value }) => ( + +) + +DownloadButton.propTypes = { + onClick: PropTypes.func.isRequired, + value: PropTypes.string.isRequired +} + +export default DownloadButton; diff --git a/src/components/footer/Footer.js b/src/components/footer/Footer.js new file mode 100644 index 0000000..1950b93 --- /dev/null +++ b/src/components/footer/Footer.js @@ -0,0 +1,36 @@ +import React from "react"; +import '../Qrcode.css'; + +const currentYear = new Date().getFullYear(); + +const Footer = () => ( +
+
+
+ 作者  + ciaochaos +   + CPunisher +  丨  + 联系我们 +
+ +
+ Copyright © {currentYear} QRBTF. 保留所有权利。 +
+ +
+
+) + +export default Footer diff --git a/src/components/header/Header.js b/src/components/header/Header.js new file mode 100644 index 0000000..233fdf0 --- /dev/null +++ b/src/components/header/Header.js @@ -0,0 +1,22 @@ +import React from "react"; +import '../Qrcode.css'; +import logo from "../../qrbtf-logo.svg"; +import InputText from "../../containers/InputText"; + +const logoStyle = { + background: `url(${logo})`, + backgroundRepeat: 'no-repeat', + backgroundPosition: 'left' +}; + +const Header = () => ( +
+
+

+
+

参数化二维码生成器 测试版

+ +
+) + +export default Header diff --git a/src/components/link/LinkButton.js b/src/components/link/LinkButton.js new file mode 100644 index 0000000..cff0741 --- /dev/null +++ b/src/components/link/LinkButton.js @@ -0,0 +1,16 @@ +import React from "react"; +import PropTypes from 'prop-types' +import '../Qrcode.css'; + +const LinkButton = ({ href, value }) => ( + + + +) + +LinkButton.propTypes = { + href: PropTypes.string.isRequired, + value: PropTypes.string.isRequired +} + +export default LinkButton; diff --git a/src/components/param/ParamColor.js b/src/components/param/ParamColor.js new file mode 100644 index 0000000..3e62e87 --- /dev/null +++ b/src/components/param/ParamColor.js @@ -0,0 +1,22 @@ +import React from 'react'; +import PropTypes from 'prop-types'; +import {SliderPicker} from 'react-color'; +import '../Qrcode.css'; + +const ParamColor = ({ rendererIndex, paramIndex, value, onChange }) => ( + +) + +ParamColor.propTypes = { + rendererIndex: PropTypes.number.isRequired, + paramIndex: PropTypes.number.isRequired, + value: PropTypes.string.isRequired, + onChange: PropTypes.func.isRequired, +} + +export default ParamColor; diff --git a/src/components/param/ParamCorrectLevel.js b/src/components/param/ParamCorrectLevel.js new file mode 100644 index 0000000..38bf243 --- /dev/null +++ b/src/components/param/ParamCorrectLevel.js @@ -0,0 +1,27 @@ +import React from 'react'; +import PropTypes from 'prop-types' +import '../Qrcode.css'; + +const ParamCorrectLevel = ({ value, onChange }) => ( + + 容错率 + + + + +) + +ParamCorrectLevel.propTypes = { + value: PropTypes.number.isRequired, + onChange: PropTypes.func.isRequired +} + +export default ParamCorrectLevel; diff --git a/src/components/param/ParamList.js b/src/components/param/ParamList.js new file mode 100644 index 0000000..fb4f334 --- /dev/null +++ b/src/components/param/ParamList.js @@ -0,0 +1,50 @@ +import React from 'react'; +import {ParamTypes} from "../../constant/ParamTypes"; +import PropTypes from "prop-types" +import ParamTextViewer from "../../containers/param/ParamTextViewer"; +import ParamSelectViewer from "../../containers/param/ParamSelectViewer"; +import ParamColorViewer from "../../containers/param/ParamColorViewer"; + +const ParamList = ({ rendererIndex, paramInfo }) => ( + paramInfo.map((item, paramIndex) => { + switch (item.type) { + case ParamTypes.TEXT_EDITOR: { + return ( + + {item.key} + + + + + ) + } + case ParamTypes.SELECTOR: { + return ( + + {item.key} + + + + + ) + } + case ParamTypes.COLOR_EDITOR: { + return ( + + {item.key} + + + + + ) + } + } + }) +) + +ParamList.propTypes = { + rendererIndex: PropTypes.number.isRequired, + paramInfo: PropTypes.array +} + +export default ParamList; diff --git a/src/components/param/ParamSelect.js b/src/components/param/ParamSelect.js new file mode 100644 index 0000000..fb145e6 --- /dev/null +++ b/src/components/param/ParamSelect.js @@ -0,0 +1,31 @@ +import React from 'react'; +import PropTypes from 'prop-types' +import '../Qrcode.css'; + +const ParamList = ({ rendererIndex, paramIndex, value, info, onChange }) => ( + +) + +ParamList.propTypes = { + rendererIndex: PropTypes.number.isRequired, + paramIndex: PropTypes.number.isRequired, + value: PropTypes.number.isRequired, + info: PropTypes.object.isRequired, + onChange: PropTypes.func.isRequired +} + +export default ParamList; diff --git a/src/components/param/ParamText.js b/src/components/param/ParamText.js new file mode 100644 index 0000000..c573290 --- /dev/null +++ b/src/components/param/ParamText.js @@ -0,0 +1,25 @@ +import React from 'react'; +import PropTypes from 'prop-types' +import '../Qrcode.css'; + +const ParamText = ({ rendererIndex, paramIndex, value, onBlur, onKeyPress }) => ( + +) + +ParamText.propTypes = { + rendererIndex: PropTypes.number.isRequired, + paramIndex: PropTypes.number.isRequired, + value: PropTypes.string.isRequired, + onBlur: PropTypes.func.isRequired, + onKeyPress: PropTypes.func.isRequired +} + +export default ParamText; diff --git a/src/components/renderer/Renderer25D.js b/src/components/renderer/Renderer25D.js new file mode 100644 index 0000000..0de8dc2 --- /dev/null +++ b/src/components/renderer/Renderer25D.js @@ -0,0 +1,82 @@ +import React, { useEffect } from "react"; +import {defaultViewBox} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; + +function listPoints(qrcode, params) { + if (!qrcode) return [] + + const nCount = qrcode.getModuleCount(); + const typeTable = getTypeTable(qrcode); + const pointList = new Array(nCount); + + let size = 1.001; + let size2 = 1.001; + let height = params[0]; + let height2 = params[1]; + let id = 0; + + 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 (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_OTHER || typeTable[x][y] == QRPointType.POS_CENTER) { + pointList.push(); + pointList.push(); + pointList.push(); + } + else { + pointList.push(); + pointList.push(); + pointList.push(); + } + } + } + + return pointList; +} + +function getParamInfo() { + return [ + { + type: ParamTypes.TEXT_EDITOR, + key: '柱体高度', + default: 0.5, + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '定位点柱体高度', + default: 0.5, + }, + ]; +} + +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); +} + +const Renderer25D = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default Renderer25D diff --git a/src/components/renderer/RendererBase.js b/src/components/renderer/RendererBase.js new file mode 100644 index 0000000..30c496d --- /dev/null +++ b/src/components/renderer/RendererBase.js @@ -0,0 +1,132 @@ +import React, { useEffect } from "react"; +import {defaultViewBox, rand} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; + +function listPoints(qrcode, params) { + if (!qrcode) return [] + + const nCount = qrcode.getModuleCount(); + const typeTable = getTypeTable(qrcode); + const pointList = new Array(nCount); + + let type = params[0]; + let size = params[1] / 100; + let opacity = params[2] / 100; + let posType = params[3]; + let id = 0; + let otherColor = params[4]; + let posColor = params[5]; + + const vw = [3, -3]; + const vh = [3, -3]; + + 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; + + if (typeTable[x][y] == QRPointType.ALIGN_CENTER || typeTable[x][y] == QRPointType.ALIGN_OTHER || typeTable[x][y] == QRPointType.TIMING) { + if (type == 0) + pointList.push() + else if (type == 1) + pointList.push() + else if (type == 2) + pointList.push() + } + else if (typeTable[x][y] == QRPointType.POS_CENTER) { + if (posType == 0) { + pointList.push(); + } else if (posType == 1) { + pointList.push() + pointList.push() + } else if (posType == 2) { + pointList.push() + pointList.push() + for (let w = 0; w < vw.length; w++) { + pointList.push() + } + for (let h = 0; h < vh.length; h++) { + pointList.push() + } + } + } + else if (typeTable[x][y] == QRPointType.POS_OTHER) { + if (posType == 0) { + pointList.push(); + } + } + else { + if (type == 0) + pointList.push() + else if (type == 1) + pointList.push() + else if (type == 2) + pointList.push() + } + } + } + + return pointList; +} + +function getParamInfo() { + return [ + { + type: ParamTypes.SELECTOR, + key: '信息点样式', + default: 0, + choices: [ + "矩形", + "圆形", + "随机" + ] + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点缩放', + default: 100 + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点不透明度', + default: 100, + }, + { + type: ParamTypes.SELECTOR, + key: '定位点样式', + default: 0, + choices: [ + "矩形", + "圆形", + "行星", + ] + }, + { + type: ParamTypes.COLOR_EDITOR, + key: '信息点颜色', + default: '#000000' + }, + { + type: ParamTypes.COLOR_EDITOR, + key: '定位点点颜色', + default: '#000000' + } + ]; +} + +const RendererBase = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RendererBase diff --git a/src/components/renderer/RendererBlank.js b/src/components/renderer/RendererBlank.js new file mode 100644 index 0000000..ab7f08b --- /dev/null +++ b/src/components/renderer/RendererBlank.js @@ -0,0 +1,25 @@ +import React, { useEffect } from "react"; +import {defaultViewBox} from "../../utils/util"; + +function listPoints(qrcode, params) { + return [] +} + +function getParamInfo() { + return []; +} + +const RenderBlank = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RenderBlank diff --git a/src/components/QrRendererDSJ.js b/src/components/renderer/RendererDSJ.js similarity index 84% rename from src/components/QrRendererDSJ.js rename to src/components/renderer/RendererDSJ.js index 337566f..c8f667a 100644 --- a/src/components/QrRendererDSJ.js +++ b/src/components/renderer/RendererDSJ.js @@ -1,21 +1,20 @@ -import React from "react"; -import './Qrcode.css' -import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; -import {defaultRenderer, defaultViewBox, rand} from "../utils/util"; +import React, { useEffect } from "react"; +import {defaultViewBox} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; -function listPoint(props) { - if (!props.qrcode) return [] +function listPoints(qrcode, params) { + if (!qrcode) return [] - const qrcode = props.qrcode; const nCount = qrcode.getModuleCount(); const typeTable = getTypeTable(qrcode); const pointList = []; const g1 = []; const g2 = []; - let width2 = props.params[0] / 100; - let width1 = props.params[1] / 100; - let posType = props.params[2]; + let width2 = params[0] / 100; + let width1 = params[1] / 100; + let posType = params[2]; let id = 0; if (width2 <= 0) width2 = 70; @@ -159,39 +158,41 @@ function listPoint(props) { return pointList; } -export default class QrRendererDSJ extends React.Component { - constructor(props) { - super(props); - if (this.props.setParamInfo) { - this.props.setParamInfo([ - { - key: '信息点缩放', - default: 70, - }, - { - key: 'x 宽度', - default: 70, - }, - { - key: '定位点样式', - default: 1, - choices: [ - "矩形", - "DSJ", - ] - }, - ] - ); - } - } - - render() { - return ( - - {listPoint(this.props)} - - ); - } +function getParamInfo() { + return [ + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点缩放', + default: 70, + }, + { + type: ParamTypes.TEXT_EDITOR, + key: 'x 宽度', + default: 70, + }, + { + type: ParamTypes.SELECTOR, + key: '定位点样式', + default: 1, + choices: [ + "矩形", + "DSJ", + ] + }, + ] } +const RenderDSJ = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RenderDSJ diff --git a/src/components/renderer/RendererImage.js b/src/components/renderer/RendererImage.js new file mode 100644 index 0000000..1352f2f --- /dev/null +++ b/src/components/renderer/RendererImage.js @@ -0,0 +1,145 @@ +import React, { useEffect } from "react"; +import {defaultViewBox} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; + +function listPoints(qrcode, params) { + if (!qrcode) return [] + + const nCount = qrcode.getModuleCount(); + const typeTable = getTypeTable(qrcode); + const pointList = new Array(nCount); + + let type = params[0]; + let size = params[1] / 100 / 3; + let opacity = params[2] / 100; + let posType = params[3]; + let id = 0; + + const vw = [3, -3]; + const vh = [3, -3]; + + if (size <= 0) size = 1.0 + + pointList.push(); + + 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() + else if (type == 1) + pointList.push() + } else { + if (type == 0) + pointList.push() + else if (type == 1) + pointList.push() + } + } + else if (typeTable[x][y] == QRPointType.POS_CENTER) { + if (qrcode.isDark(x, y)) { + if (posType == 0) { + pointList.push(); + } else if (posType == 1) { + pointList.push() + pointList.push() + pointList.push() + } else if (posType == 2) { + pointList.push() + pointList.push() + pointList.push() + for (let w = 0; w < vw.length; w++) { + pointList.push() + } + for (let h = 0; h < vh.length; h++) { + pointList.push() + } + } + } + + } + else if (typeTable[x][y] == QRPointType.POS_OTHER) { + if (qrcode.isDark(x, y)) { + if (posType == 0) { + pointList.push(); + } + } else { + if (posType == 0) { + pointList.push(); + } + } + + } + else { + if (qrcode.isDark(x, y)) { + if (type == 0) + pointList.push() + else if (type == 1) + pointList.push() + } else { + if (type == 0) + pointList.push() + else if (type == 1) + pointList.push() + } + + } + } + } + + return pointList; +} + +function getParamInfo() { + return [ + { + type: ParamTypes.SELECTOR, + key: '信息点样式', + default: 0, + choices: [ + "矩形", + "圆形", + "随机" + ] + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点缩放', + default: 100 + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点不透明度', + default: 100, + }, + { + type: ParamTypes.SELECTOR, + key: '定位点样式', + default: 0, + choices: [ + "矩形", + "圆形", + "行星", + ] + }, + ]; +} + +const RendererImage = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} +let data = "" + +export default RendererImage diff --git a/src/components/QrRendererRandRect.js b/src/components/renderer/RendererRandRect.js similarity index 62% rename from src/components/QrRendererRandRect.js rename to src/components/renderer/RendererRandRect.js index a6cd774..cf357bf 100644 --- a/src/components/QrRendererRandRect.js +++ b/src/components/renderer/RendererRandRect.js @@ -1,11 +1,11 @@ -import React from "react"; -import './Qrcode.css' -import {defaultRenderer, defaultViewBox, rand} from "../utils/util"; +import React, { useEffect } from "react"; +import {defaultViewBox, rand} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; -function listPoint(props) { - if (!props.qrcode) return [] +function listPoints(qrcode, params) { + if (!qrcode) return [] - const qrcode = props.qrcode; const nCount = qrcode.getModuleCount(); const pointList = []; let id = 0; @@ -38,14 +38,21 @@ function listPoint(props) { return pointList; } -export default class QrRendererRandRect extends React.Component { - render() { - return ( - - {listPoint(this.props)} - - ); - } +function getParamInfo() { + return [] } +const RendererRandRect = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RendererRandRect diff --git a/src/components/QrRendererBase.js b/src/components/renderer/RendererRandRound.js similarity index 63% rename from src/components/QrRendererBase.js rename to src/components/renderer/RendererRandRound.js index 3c3e103..130d7f1 100644 --- a/src/components/QrRendererBase.js +++ b/src/components/renderer/RendererRandRound.js @@ -1,20 +1,19 @@ -import React from "react"; -import './Qrcode.css' -import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; -import {defaultRenderer, defaultViewBox, rand} from "../utils/util"; +import React, { useEffect } from "react"; +import {defaultViewBox, rand} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; -function listPoint(props) { - if (!props.qrcode) return [] +function listPoints(qrcode, params) { + if (!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 type = params[0]; + let size = params[1] / 100; + let opacity = params[2] / 100; + let posType = params[3]; let id = 0; const vw = [3, -3]; @@ -70,49 +69,52 @@ function listPoint(props) { return pointList; } -export default class QrRendererBase 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 ( - - {listPoint(this.props)} - - ); - } +function getParamInfo() { + return [ + { + type: ParamTypes.SELECTOR, + key: '信息点样式', + default: 2, + choices: [ + "矩形", + "圆形", + "随机" + ] + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点缩放', + default: 80 + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点不透明度', + default: 100, + }, + { + type: ParamTypes.SELECTOR, + key: '定位点样式', + default: 2, + choices: [ + "矩形", + "圆形", + "行星", + ] + }, + ]; } +const RendererRandRound = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RendererRandRound diff --git a/src/components/QrRendererRound.js b/src/components/renderer/RendererRound.js similarity index 62% rename from src/components/QrRendererRound.js rename to src/components/renderer/RendererRound.js index d23f7f1..801f4fa 100644 --- a/src/components/QrRendererRound.js +++ b/src/components/renderer/RendererRound.js @@ -1,20 +1,19 @@ -import React from "react"; -import './Qrcode.css' -import {getTypeTable, QRPointType} from "../utils/qrcodeHandler"; -import {defaultRenderer, defaultViewBox, rand} from "../utils/util"; +import React, { useEffect } from "react"; +import {defaultViewBox, rand} from "../../utils/util"; +import {ParamTypes} from "../../constant/ParamTypes"; +import {getTypeTable, QRPointType} from "../../utils/qrcodeHandler"; -function listPoint(props) { - if (!props.qrcode) return [] +function listPoints(qrcode, params) { + if (!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 type = params[0]; + let size = params[1] / 100; + let opacity = params[2] / 100; + let posType = params[3]; let id = 0; const vw = [3, -3]; @@ -70,49 +69,52 @@ function listPoint(props) { return pointList; } -export default class QrRendererRound extends React.Component { - constructor(props) { - super(props); - if (this.props.setParamInfo) { - this.props.setParamInfo([ - { - key: '信息点样式', - default: 1, - choices: [ - "矩形", - "圆形", - "随机" - ] - }, - { - key: '信息点缩放', - default: 50 - }, - { - key: '信息点不透明度', - default: 30, - }, - { - key: '定位点样式', - default: 1, - choices: [ - "矩形", - "圆形", - "行星", - ] - }, - ] - ); - } - } - - render() { - return ( - - {listPoint(this.props)} - - ); - } +function getParamInfo() { + return [ + { + type: ParamTypes.SELECTOR, + key: '信息点样式', + default: 1, + choices: [ + "矩形", + "圆形", + "随机" + ] + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点缩放', + default: 50 + }, + { + type: ParamTypes.TEXT_EDITOR, + key: '信息点不透明度', + default: 30, + }, + { + type: ParamTypes.SELECTOR, + key: '定位点样式', + default: 1, + choices: [ + "矩形", + "圆形", + "行星", + ] + }, + ] } +const RendererRound = ({ qrcode, params, setParamInfo}) => { + useEffect(() => { + setParamInfo(getParamInfo()); + }, [setParamInfo]); + + return ( + + {listPoints(qrcode, params)} + + ) +} + +export default RendererRound diff --git a/src/components/style/Renderer.js b/src/components/style/Renderer.js new file mode 100644 index 0000000..bbf4347 --- /dev/null +++ b/src/components/style/Renderer.js @@ -0,0 +1,11 @@ +import React from "react"; + +const Renderer = ({ rendererType, ...other }) => ( + React.createElement(rendererType, other) +) + +function areEqual(prevProps, nextProps) { + return !(prevProps.selected == true || nextProps.selected == true) +} + +export default React.memo(Renderer, areEqual) diff --git a/src/components/style/Style.js b/src/components/style/Style.js new file mode 100644 index 0000000..7369d07 --- /dev/null +++ b/src/components/style/Style.js @@ -0,0 +1,30 @@ +import React from "react"; +import PropTypes from 'prop-types' + +function calClassName(selected) { + if (selected === true) return 'Qr-item Qr-item-selected'; + return 'Qr-item'; +} + +const Style = ({ value, renderer, selected, onSelected }) => ( +
+
+
+ {renderer} +
+
+
+ {value} +
+
+); + +Style.propTypes = { + value: PropTypes.string.isRequired, + renderer: PropTypes.object.isRequired, + selected: PropTypes.bool.isRequired, + onSelected: PropTypes.func.isRequired +} + +export default Style; diff --git a/src/components/style/StyleList.js b/src/components/style/StyleList.js new file mode 100644 index 0000000..4a9f57f --- /dev/null +++ b/src/components/style/StyleList.js @@ -0,0 +1,26 @@ +import React from 'react' +import PropTypes from 'prop-types' +import Style from "./Style"; + +const StyleList = ({ styles, onSelected }) => ( +
+ {styles.map((style, index) => +