Skip to content

Commit 804de72

Browse files
committed
feat: add test files & fix 40+ text qrcode
fix #13
1 parent 37be3bc commit 804de72

File tree

10 files changed

+2432
-784
lines changed

10 files changed

+2432
-784
lines changed

babel.config.js

+31
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
/* eslint-disable import/no-commonjs */
2+
const apis = require('@tarojs/taro-h5/dist/taroApis')
3+
4+
module.exports = {
5+
presets: [
6+
[
7+
'@babel/env',
8+
{
9+
spec: true,
10+
useBuiltIns: false,
11+
},
12+
],
13+
],
14+
plugins: [
15+
'@babel/plugin-proposal-class-properties',
16+
[
17+
'@babel/plugin-transform-react-jsx',
18+
{
19+
pragma: 'Nerv.createElement',
20+
},
21+
],
22+
['@babel/plugin-proposal-object-rest-spread'],
23+
[
24+
'babel-plugin-transform-taroapi',
25+
{
26+
apis,
27+
packageName: '@tarojs/taro-h5',
28+
},
29+
],
30+
],
31+
}

package.json

+3-2
Original file line numberDiff line numberDiff line change
@@ -64,7 +64,7 @@
6464
"@types/webpack-env": "^1.13.6",
6565
"babel-core": "^7.0.0-bridge.0",
6666
"babel-eslint": "^8.2.3",
67-
"babel-jest": "^24.9.0",
67+
"babel-jest": "23.6.0",
6868
"babel-plugin-transform-class-properties": "^6.24.1",
6969
"babel-plugin-transform-decorators-legacy": "^1.3.4",
7070
"babel-plugin-transform-jsx-stylesheet": "^0.6.5",
@@ -78,10 +78,11 @@
7878
"eslint-plugin-react-hooks": "^2.3.0",
7979
"eslint-plugin-taro": "1.3.29",
8080
"husky": ">=1",
81-
"jest": "^24.9.0",
81+
"jest": "23.6.0",
8282
"lint-staged": ">=8",
8383
"miniprogram-automator": "^0.8.0",
8484
"nerv-devtools": "^1.5.6",
85+
"nerv-server": "^1.5.6",
8586
"nervjs": "^1.5.6",
8687
"sinon": "^7.5.0"
8788
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
// Jest Snapshot v1, https://goo.gl/fbAQLP
2+
3+
exports[`Barcode test Barcode test suites 1`] = `"<div class=\\"taro-img\\" style=\\"width:300px;height:60px;\\"><img class=\\"taro-img__mode-scaletofill\\" src=\\"\\"/></div>"`;

src/components/Barcode/index.js

+3-12
Original file line numberDiff line numberDiff line change
@@ -1,19 +1,10 @@
1-
import Taro, { useState, useEffect } from '@tarojs/taro'
1+
import Taro, { useMemo } from '@tarojs/taro'
22
import PropTypes from 'prop-types'
33
import { Image } from '@tarojs/components'
4-
import utils from '../../utils'
4+
import barcode from '../../utils/barcode'
55

66
function BarCode({ text, scale, width, height }) {
7-
const [image, setImage] = useState('')
8-
9-
useEffect(() => {
10-
if (text) {
11-
setImage(utils.barcode({ text, scale }))
12-
} else {
13-
setImage('')
14-
}
15-
}, [text, scale])
16-
7+
const image = useMemo(() => barcode({ text, scale }), [text, scale])
178
const widthString = width ? width + 'px' : ''
189
const heightString = height ? height + 'px' : ''
1910
const style = { width: widthString, height: heightString }

src/components/Barcode/index.test.js

+12
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
/* eslint-disable react/react-in-jsx-scope */
2+
// eslint-disable-next-line no-unused-vars
3+
import Nerv from 'nervjs'
4+
import { renderToString } from 'nerv-server'
5+
import Barcode from '../../../.temp/components/Barcode'
6+
7+
describe('Barcode test', () => {
8+
it('Barcode test suites', () => {
9+
const component = renderToString(<Barcode text='hello world' />)
10+
expect(component).toMatchSnapshot()
11+
})
12+
})
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
// Jest Snapshot v1, https://goo.gl/fbAQLP
2+
3+
exports[`QRCode test 40+ words 1`] = `"<div class=\\"taro-img\\" style=\\"width:100px;height:100px;\\"><img class=\\"taro-img__mode-scaletofill\\" src=\\"\\"/></div>"`;
4+
5+
exports[`QRCode test hello world 1`] = `"<div class=\\"taro-img\\" style=\\"width:100px;height:100px;\\"><img class=\\"taro-img__mode-scaletofill\\" src=\\"\\"/></div>"`;

src/components/Qrcode/index.js

+5-12
Original file line numberDiff line numberDiff line change
@@ -1,20 +1,13 @@
1-
import Taro, { useState, useEffect } from '@tarojs/taro'
1+
import Taro, { useMemo } from '@tarojs/taro'
22
import PropTypes from 'prop-types'
33
import { Image } from '@tarojs/components'
4-
import { createQrCodeImg } from 'wx-base64-qrcode'
4+
import { createQrCodeImg } from '../../utils/qrcode'
55

66
function QRCode({ text, size, scale, typeNumber, errorCorrectLevel }) {
7-
const [image, setImage] = useState('')
8-
9-
useEffect(() => {
10-
if (text) {
11-
const options = { errorCorrectLevel, typeNumber, size: size * scale }
12-
setImage(createQrCodeImg(text, options))
13-
} else {
14-
setImage('')
15-
}
7+
const image = useMemo(() => {
8+
const options = { errorCorrectLevel, typeNumber, size: size * scale }
9+
return createQrCodeImg(text, options)
1610
}, [text, scale, size, errorCorrectLevel, typeNumber])
17-
1811
const style = { width: size + 'px', height: size + 'px' }
1912
return <Image style={style} src={image} />
2013
}

src/components/Qrcode/index.test.js

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
/* eslint-disable react/react-in-jsx-scope */
2+
// eslint-disable-next-line no-unused-vars
3+
import Nerv from 'nervjs'
4+
import { renderToString } from 'nerv-server'
5+
import QRCode from '../../../.temp/components/Qrcode'
6+
7+
describe('QRCode test', () => {
8+
it('hello world', () => {
9+
const component = renderToString(<QRCode text='hello world' />)
10+
expect(component).toMatchSnapshot()
11+
})
12+
it('40+ words', () => {
13+
const component = renderToString(
14+
<QRCode text='12345678901234567890123456789012345678901234567890' />,
15+
)
16+
expect(component).toMatchSnapshot()
17+
})
18+
})

0 commit comments

Comments
 (0)