mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
feat(SwipeCell): optimize code (#5076)
This commit is contained in:
parent
4e5bc170e1
commit
aba9e3f009
@ -55,10 +55,13 @@ export default createComponent({
|
||||
return 0;
|
||||
},
|
||||
|
||||
// @exposed-api
|
||||
open(position) {
|
||||
const offset = position === 'left' ? this.computedLeftWidth : -this.computedRightWidth;
|
||||
const offset =
|
||||
position === 'left' ? this.computedLeftWidth : -this.computedRightWidth;
|
||||
|
||||
this.swipeMove(offset);
|
||||
this.resetSwipeStatus();
|
||||
this.opened = true;
|
||||
|
||||
this.$emit('open', {
|
||||
position,
|
||||
@ -66,50 +69,24 @@ export default createComponent({
|
||||
});
|
||||
},
|
||||
|
||||
// @exposed-api
|
||||
close() {
|
||||
this.offset = 0;
|
||||
},
|
||||
|
||||
resetSwipeStatus() {
|
||||
this.swiping = false;
|
||||
this.opened = true;
|
||||
},
|
||||
|
||||
swipeMove(offset = 0) {
|
||||
this.offset = range(offset, -this.computedRightWidth, this.computedLeftWidth);
|
||||
this.offset = range(
|
||||
offset,
|
||||
-this.computedRightWidth,
|
||||
this.computedLeftWidth
|
||||
);
|
||||
|
||||
if (this.offset) {
|
||||
this.swiping = true;
|
||||
} else {
|
||||
if (!this.offset) {
|
||||
this.opened = false;
|
||||
}
|
||||
},
|
||||
|
||||
swipeLeaveTransition(direction) {
|
||||
const { offset, computedLeftWidth, computedRightWidth } = this;
|
||||
const threshold = this.opened ? 1 - THRESHOLD : THRESHOLD;
|
||||
|
||||
// right
|
||||
if (
|
||||
direction === 'right' &&
|
||||
-offset > computedRightWidth * threshold &&
|
||||
computedRightWidth > 0
|
||||
) {
|
||||
this.open('right');
|
||||
// left
|
||||
} else if (
|
||||
direction === 'left' &&
|
||||
offset > computedLeftWidth * threshold &&
|
||||
computedLeftWidth > 0
|
||||
) {
|
||||
this.open('left');
|
||||
// reset
|
||||
} else {
|
||||
this.swipeMove(0);
|
||||
}
|
||||
},
|
||||
|
||||
startDrag(event) {
|
||||
onTouchStart(event) {
|
||||
if (this.disabled) {
|
||||
return;
|
||||
}
|
||||
@ -119,7 +96,7 @@ export default createComponent({
|
||||
this.touchStart(event);
|
||||
},
|
||||
|
||||
onDrag(event) {
|
||||
onTouchMove(event) {
|
||||
if (this.disabled) {
|
||||
return;
|
||||
}
|
||||
@ -127,9 +104,9 @@ export default createComponent({
|
||||
this.touchMove(event);
|
||||
|
||||
if (this.direction === 'horizontal') {
|
||||
const shouldPrevent = !this.opened || this.deltaX * this.startOffset < 0;
|
||||
const isPrevent = !this.opened || this.deltaX * this.startOffset < 0;
|
||||
|
||||
if (shouldPrevent) {
|
||||
if (isPrevent) {
|
||||
preventDefault(event, this.stopPropagation);
|
||||
}
|
||||
|
||||
@ -137,14 +114,37 @@ export default createComponent({
|
||||
}
|
||||
},
|
||||
|
||||
endDrag() {
|
||||
onTouchEnd() {
|
||||
if (this.disabled) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (this.dragging) {
|
||||
this.toggle(this.offset > 0 ? 'left' : 'right');
|
||||
}
|
||||
|
||||
this.dragging = false;
|
||||
if (this.swiping) {
|
||||
this.swipeLeaveTransition(this.offset > 0 ? 'left' : 'right');
|
||||
},
|
||||
|
||||
toggle(direction) {
|
||||
const offset = Math.abs(this.offset);
|
||||
const threshold = this.opened ? 1 - THRESHOLD : THRESHOLD;
|
||||
const { computedLeftWidth, computedRightWidth } = this;
|
||||
|
||||
if (
|
||||
computedRightWidth &&
|
||||
direction === 'right' &&
|
||||
offset > computedRightWidth * threshold
|
||||
) {
|
||||
this.open('right');
|
||||
} else if (
|
||||
computedLeftWidth &&
|
||||
direction === 'left' &&
|
||||
offset > computedLeftWidth * threshold
|
||||
) {
|
||||
this.open('left');
|
||||
} else {
|
||||
this.swipeMove(0);
|
||||
}
|
||||
},
|
||||
|
||||
@ -160,17 +160,47 @@ export default createComponent({
|
||||
} else {
|
||||
this.swipeMove(0);
|
||||
}
|
||||
},
|
||||
|
||||
getClickHandler(position, stop) {
|
||||
return event => {
|
||||
if (stop) {
|
||||
event.stopPropagation();
|
||||
}
|
||||
this.onClick(position);
|
||||
};
|
||||
},
|
||||
|
||||
genLeftPart() {
|
||||
if (this.slots('left')) {
|
||||
return (
|
||||
<div
|
||||
ref="left"
|
||||
class={bem('left')}
|
||||
onClick={this.getClickHandler('left', true)}
|
||||
>
|
||||
{this.slots('left')}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
},
|
||||
|
||||
genRightPart() {
|
||||
if (this.slots('right')) {
|
||||
return (
|
||||
<div
|
||||
ref="right"
|
||||
class={bem('right')}
|
||||
onClick={this.getClickHandler('right', true)}
|
||||
>
|
||||
{this.slots('right')}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
render() {
|
||||
const onClick = (position, stop) => event => {
|
||||
if (stop) {
|
||||
event.stopPropagation();
|
||||
}
|
||||
this.onClick(position);
|
||||
};
|
||||
|
||||
const wrapperStyle = {
|
||||
transform: `translate3d(${this.offset}px, 0, 0)`,
|
||||
transitionDuration: this.dragging ? '0s' : '.6s'
|
||||
@ -179,30 +209,16 @@ export default createComponent({
|
||||
return (
|
||||
<div
|
||||
class={bem()}
|
||||
onClick={onClick('cell')}
|
||||
onTouchstart={this.startDrag}
|
||||
onTouchmove={this.onDrag}
|
||||
onTouchend={this.endDrag}
|
||||
onTouchcancel={this.endDrag}
|
||||
onClick={this.getClickHandler('cell')}
|
||||
onTouchstart={this.onTouchStart}
|
||||
onTouchmove={this.onTouchMove}
|
||||
onTouchend={this.onTouchEnd}
|
||||
onTouchcancel={this.onTouchEnd}
|
||||
>
|
||||
<div
|
||||
class={bem('wrapper')}
|
||||
style={wrapperStyle}
|
||||
onTransitionend={() => {
|
||||
this.swiping = false;
|
||||
}}
|
||||
>
|
||||
{this.slots('left') && (
|
||||
<div ref="left" class={bem('left')} onClick={onClick('left', true)}>
|
||||
{this.slots('left')}
|
||||
</div>
|
||||
)}
|
||||
<div class={bem('wrapper')} style={wrapperStyle}>
|
||||
{this.genLeftPart()}
|
||||
{this.slots()}
|
||||
{this.slots('right') && (
|
||||
<div ref="right" class={bem('right')} onClick={onClick('right', true)}>
|
||||
{this.slots('right')}
|
||||
</div>
|
||||
)}
|
||||
{this.genRightPart()}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
|
Loading…
x
Reference in New Issue
Block a user