Skip to content

Commit

Permalink
feat(h5): cover-image组件 (#10606)
Browse files Browse the repository at this point in the history
* feat(h5): cover-image组件

* feat(h5): cover-image组件

* feat(h5): code style

* feat(h5): cover image 目录结构调整

* feat(h5): cover-image 测试用例

* fix(h5): 测试用例

Co-authored-by: tangjiao11 <[email protected]>
Co-authored-by: chenjiajian <[email protected]>
  • Loading branch information
3 people authored Nov 23, 2021
1 parent 1833b1a commit 47663dd
Show file tree
Hide file tree
Showing 5 changed files with 124 additions and 22 deletions.
65 changes: 65 additions & 0 deletions packages/taro-components/__tests__/cover-image.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
import React from 'react'
import * as assert from 'assert'
import * as sinon from 'sinon'
import { CoverImage } from '../h5/react'
import { mount } from './test-tools'
import { delay } from './utils'

// eslint-disable-next-line @typescript-eslint/no-unused-vars
const h = React.createElement

describe('CoverImage', () => {
/**
* @type {HTMLElement}
*/
let scratch

const IMAGE = ''

beforeEach(() => {
scratch = document.createElement('div')
document.body.appendChild(scratch)
})

afterEach(() => {
scratch.parentNode.removeChild(scratch)
scratch = null
})

it('should show an cover-image', async () => {
const wrapper = await mount(<CoverImage src={IMAGE} />, scratch)

assert(wrapper.find(`img[src='${IMAGE}']`))
})

it('events', async () => {
const onLoad = sinon.spy()
const onError = sinon.spy()
const app = (
<CoverImage
src=''
onLoad={onLoad}
onError={ev => {
// 停止冒泡,防止 Jasmine 监听到 onError 事件导致用例直接失败
ev.stopPropagation()
onError()
}}
/>
)
const wrapper = await mount(app, scratch)

await delay(50)
assert(onLoad.callCount === 0)
assert(onError.callCount === 1)

wrapper.setProps({ src: IMAGE })

await delay(2000)
assert(onLoad.callCount === 1)
const { width, height } = onLoad.firstCall.args[0].detail
const image = wrapper.find('img')
assert(width === image.width)
assert(height === image.height)
assert(onError.callCount === 1)
})
})
5 changes: 0 additions & 5 deletions packages/taro-components/__tests__/unimplemented.spec.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import React from 'react'
import ReactDOM from 'react-dom'
import {
CoverImage,
MovableArea,
MovableView,
PickerView,
Expand Down Expand Up @@ -80,10 +79,6 @@ describe('unimplemented', () => {
console.error.restore()
})

it('CoverImage', async () => {
await testComponent(CoverImage)
})

it('MovableArea', async () => {
await testComponent(MovableArea)
})
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
// eslint-disable-next-line @typescript-eslint/no-unused-vars
import { Component, Prop, Event, h, ComponentInterface, EventEmitter } from '@stencil/core'

@Component({
tag: 'taro-cover-image-core',
styleUrl: './style/index.scss'
})
export class CoverImage implements ComponentInterface {
@Prop() src: string
@Prop() nativeProps = {}
@Event({
eventName: 'load'
}) onLoad: EventEmitter

@Event({
eventName: 'error'
}) onError: EventEmitter

private imgRef: HTMLImageElement

imageOnLoad () {
const {
width,
height,
} = this.imgRef

this.onLoad.emit({
width,
height
})
}

imageOnError () {
this.onError.emit()
}

render () {
const {
src,
imageOnLoad,
imageOnError,
nativeProps
} = this
return (
<img
ref={img => (this.imgRef = img!)}
src={src}
onLoad={imageOnLoad.bind(this)}
onError={imageOnError.bind(this)}
{...nativeProps}
/>
)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
taro-cover-image-core {
overflow: hidden;
width: 320px;
height: 240px;
}
17 changes: 0 additions & 17 deletions packages/taro-components/src/components/cover-view/cover-image.tsx

This file was deleted.

0 comments on commit 47663dd

Please sign in to comment.