omi/packages/omi-tap/index.js

46 lines
1.0 KiB
JavaScript
Raw Normal View History

2018-10-25 15:35:39 +08:00
import { WeElement, define } from "omi";
class OmiTap extends WeElement {
install() {
this._handleTouchStart = this._handleTouchStart.bind(this)
this._handleTouchEnd = this._handleTouchEnd.bind(this)
this._x = null
this._y = null
this._scrollTop = null
2018-10-28 21:48:52 +08:00
let p = this.parentNode
while (p && !this.css) {
if(p.host){
this.css = p.host.css
}else{
p = p.parentNode
}
}
2018-10-25 15:35:39 +08:00
}
_handleTouchStart(evt) {
this._x = evt.touches[0].pageX
this._y = evt.touches[0].pageY
this._scrollTop = document.body.scrollTop
}
_handleTouchEnd(evt) {
if (Math.abs(evt.changedTouches[0].pageX - this._x) < 30 && Math.abs(evt.changedTouches[0].pageY - this._y) < 30 && Math.abs(document.body.scrollTop - this._scrollTop) < 30) {
this.props.onTap(evt)
}
}
render() {
const c = this.props.children[0]
!c.attributes && (c.attributes = {})
Object.assign(c.attributes, {
onTouchStart: this._handleTouchStart,
onTouchEnd: this._handleTouchEnd
})
return c
}
}
2018-10-28 21:48:52 +08:00
define("omi-tap", OmiTap)