| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 | import { isPC } from "./isPC"export default {	data() {		return {			position: [],			button: {},			btn: "[]"		}	},	// computed: {	// 	pos() {	// 		return JSON.stringify(this.position)	// 	},	// 	btn() {	// 		return JSON.stringify(this.button)	// 	}	// },	watch: {		button: {			handler(newVal) {				this.btn = JSON.stringify(newVal)			},			deep: true		},		show(newVal) {			if (this.autoClose) return			if (!this.button) {				this.init()				return			}			this.button.show = newVal		},		leftOptions() {			this.init()		},		rightOptions() {			this.init()		}	},	created() {		if (this.swipeaction.children !== undefined) {			this.swipeaction.children.push(this)		}	},	mounted() {		this.init()	},	beforeDestroy() {		this.swipeaction.children.forEach((item, index) => {			if (item === this) {				this.swipeaction.children.splice(index, 1)			}		})	},	methods: {		init() {			clearTimeout(this.swipetimer)			this.swipetimer = setTimeout(() => {				this.getButtonSize()			}, 50)		},		closeSwipe(e) {			if (!this.autoClose) return			this.swipeaction.closeOther(this)		},		change(e) {			this.$emit('change', e.open)			let show = this.button.show			if (show !== e.open) {				this.button.show = e.open			}		},		appTouchStart(e) {			// #ifdef H5			if(isPC()) return			// #endif			const {				clientX			} = e.changedTouches[0]			this.clientX = clientX			this.timestamp = new Date().getTime()		},		appTouchEnd(e, index, item, position) {			// #ifdef H5			if(isPC()) return			// #endif			const {				clientX			} = e.changedTouches[0]			// fixed by xxxx 模拟点击事件,解决 ios 13 点击区域错位的问题			let diff = Math.abs(this.clientX - clientX)			let time = (new Date().getTime()) - this.timestamp			if (diff < 40 && time < 300) {				this.$emit('click', {					content: item,					index,					position				})			}		},		onClickForPC(index, item, position) {			// #ifdef H5			if(!isPC()) return			// #endif			this.$emit('click', {				content: item,				index,				position			})		},		getButtonSize() {			const views = uni.createSelectorQuery().in(this)			views				.selectAll('.uni-swipe_button-group')				.boundingClientRect(data => {					let show = 'none'					if (this.autoClose) {						show = 'none'					} else {						show = this.show					}					this.button = {						data,						show					}				})				.exec()		}	}}
 |