mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
286 lines
8.0 KiB
JavaScript
286 lines
8.0 KiB
JavaScript
'use strict';
|
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
var color_1 = require('../common/color');
|
|
var component_1 = require('../common/component');
|
|
var utils_1 = require('../common/utils');
|
|
var page_scroll_1 = require('../mixins/page-scroll');
|
|
var indexList = function () {
|
|
var indexList = [];
|
|
var charCodeOfA = 'A'.charCodeAt(0);
|
|
for (var i = 0; i < 26; i++) {
|
|
indexList.push(String.fromCharCode(charCodeOfA + i));
|
|
}
|
|
return indexList;
|
|
};
|
|
component_1.VantComponent({
|
|
relation: {
|
|
name: 'index-anchor',
|
|
type: 'descendant',
|
|
current: 'index-bar',
|
|
linked: function () {
|
|
this.updateData();
|
|
},
|
|
unlinked: function () {
|
|
this.updateData();
|
|
},
|
|
},
|
|
props: {
|
|
sticky: {
|
|
type: Boolean,
|
|
value: true,
|
|
},
|
|
zIndex: {
|
|
type: Number,
|
|
value: 1,
|
|
},
|
|
highlightColor: {
|
|
type: String,
|
|
value: color_1.GREEN,
|
|
},
|
|
stickyOffsetTop: {
|
|
type: Number,
|
|
value: 0,
|
|
},
|
|
indexList: {
|
|
type: Array,
|
|
value: indexList(),
|
|
},
|
|
},
|
|
mixins: [
|
|
page_scroll_1.pageScrollMixin(function (event) {
|
|
this.scrollTop =
|
|
(event === null || event === void 0 ? void 0 : event.scrollTop) || 0;
|
|
this.onScroll();
|
|
}),
|
|
],
|
|
data: {
|
|
activeAnchorIndex: null,
|
|
showSidebar: false,
|
|
},
|
|
created: function () {
|
|
this.scrollTop = 0;
|
|
},
|
|
methods: {
|
|
updateData: function () {
|
|
var _this = this;
|
|
wx.nextTick(function () {
|
|
if (_this.timer != null) {
|
|
clearTimeout(_this.timer);
|
|
}
|
|
_this.timer = setTimeout(function () {
|
|
_this.setData({
|
|
showSidebar: !!_this.children.length,
|
|
});
|
|
_this.setRect().then(function () {
|
|
_this.onScroll();
|
|
});
|
|
}, 0);
|
|
});
|
|
},
|
|
setRect: function () {
|
|
return Promise.all([
|
|
this.setAnchorsRect(),
|
|
this.setListRect(),
|
|
this.setSiderbarRect(),
|
|
]);
|
|
},
|
|
setAnchorsRect: function () {
|
|
var _this = this;
|
|
return Promise.all(
|
|
this.children.map(function (anchor) {
|
|
return utils_1.getRect
|
|
.call(anchor, '.van-index-anchor-wrapper')
|
|
.then(function (rect) {
|
|
Object.assign(anchor, {
|
|
height: rect.height,
|
|
top: rect.top + _this.scrollTop,
|
|
});
|
|
});
|
|
})
|
|
);
|
|
},
|
|
setListRect: function () {
|
|
var _this = this;
|
|
return utils_1.getRect.call(this, '.van-index-bar').then(function (rect) {
|
|
Object.assign(_this, {
|
|
height: rect.height,
|
|
top: rect.top + _this.scrollTop,
|
|
});
|
|
});
|
|
},
|
|
setSiderbarRect: function () {
|
|
var _this = this;
|
|
return utils_1.getRect
|
|
.call(this, '.van-index-bar__sidebar')
|
|
.then(function (res) {
|
|
_this.sidebar = {
|
|
height: res.height,
|
|
top: res.top,
|
|
};
|
|
});
|
|
},
|
|
setDiffData: function (_a) {
|
|
var target = _a.target,
|
|
data = _a.data;
|
|
var diffData = {};
|
|
Object.keys(data).forEach(function (key) {
|
|
if (target.data[key] !== data[key]) {
|
|
diffData[key] = data[key];
|
|
}
|
|
});
|
|
if (Object.keys(diffData).length) {
|
|
target.setData(diffData);
|
|
}
|
|
},
|
|
getAnchorRect: function (anchor) {
|
|
return utils_1.getRect
|
|
.call(anchor, '.van-index-anchor-wrapper')
|
|
.then(function (rect) {
|
|
return {
|
|
height: rect.height,
|
|
top: rect.top,
|
|
};
|
|
});
|
|
},
|
|
getActiveAnchorIndex: function () {
|
|
var _a = this,
|
|
children = _a.children,
|
|
scrollTop = _a.scrollTop;
|
|
var _b = this.data,
|
|
sticky = _b.sticky,
|
|
stickyOffsetTop = _b.stickyOffsetTop;
|
|
for (var i = this.children.length - 1; i >= 0; i--) {
|
|
var preAnchorHeight = i > 0 ? children[i - 1].height : 0;
|
|
var reachTop = sticky ? preAnchorHeight + stickyOffsetTop : 0;
|
|
if (reachTop + scrollTop >= children[i].top) {
|
|
return i;
|
|
}
|
|
}
|
|
return -1;
|
|
},
|
|
onScroll: function () {
|
|
var _this = this;
|
|
var _a = this,
|
|
_b = _a.children,
|
|
children = _b === void 0 ? [] : _b,
|
|
scrollTop = _a.scrollTop;
|
|
if (!children.length) {
|
|
return;
|
|
}
|
|
var _c = this.data,
|
|
sticky = _c.sticky,
|
|
stickyOffsetTop = _c.stickyOffsetTop,
|
|
zIndex = _c.zIndex,
|
|
highlightColor = _c.highlightColor;
|
|
var active = this.getActiveAnchorIndex();
|
|
this.setDiffData({
|
|
target: this,
|
|
data: {
|
|
activeAnchorIndex: active,
|
|
},
|
|
});
|
|
if (sticky) {
|
|
var isActiveAnchorSticky_1 = false;
|
|
if (active !== -1) {
|
|
isActiveAnchorSticky_1 =
|
|
children[active].top <= stickyOffsetTop + scrollTop;
|
|
}
|
|
children.forEach(function (item, index) {
|
|
if (index === active) {
|
|
var wrapperStyle = '';
|
|
var anchorStyle =
|
|
'\n color: ' + highlightColor + ';\n ';
|
|
if (isActiveAnchorSticky_1) {
|
|
wrapperStyle =
|
|
'\n height: ' +
|
|
children[index].height +
|
|
'px;\n ';
|
|
anchorStyle =
|
|
'\n position: fixed;\n top: ' +
|
|
stickyOffsetTop +
|
|
'px;\n z-index: ' +
|
|
zIndex +
|
|
';\n color: ' +
|
|
highlightColor +
|
|
';\n ';
|
|
}
|
|
_this.setDiffData({
|
|
target: item,
|
|
data: {
|
|
active: true,
|
|
anchorStyle: anchorStyle,
|
|
wrapperStyle: wrapperStyle,
|
|
},
|
|
});
|
|
} else if (index === active - 1) {
|
|
var currentAnchor = children[index];
|
|
var currentOffsetTop = currentAnchor.top;
|
|
var targetOffsetTop =
|
|
index === children.length - 1
|
|
? _this.top
|
|
: children[index + 1].top;
|
|
var parentOffsetHeight = targetOffsetTop - currentOffsetTop;
|
|
var translateY = parentOffsetHeight - currentAnchor.height;
|
|
var anchorStyle =
|
|
'\n position: relative;\n transform: translate3d(0, ' +
|
|
translateY +
|
|
'px, 0);\n z-index: ' +
|
|
zIndex +
|
|
';\n color: ' +
|
|
highlightColor +
|
|
';\n ';
|
|
_this.setDiffData({
|
|
target: item,
|
|
data: {
|
|
active: true,
|
|
anchorStyle: anchorStyle,
|
|
},
|
|
});
|
|
} else {
|
|
_this.setDiffData({
|
|
target: item,
|
|
data: {
|
|
active: false,
|
|
anchorStyle: '',
|
|
wrapperStyle: '',
|
|
},
|
|
});
|
|
}
|
|
});
|
|
}
|
|
},
|
|
onClick: function (event) {
|
|
this.scrollToAnchor(event.target.dataset.index);
|
|
},
|
|
onTouchMove: function (event) {
|
|
var sidebarLength = this.children.length;
|
|
var touch = event.touches[0];
|
|
var itemHeight = this.sidebar.height / sidebarLength;
|
|
var index = Math.floor((touch.clientY - this.sidebar.top) / itemHeight);
|
|
if (index < 0) {
|
|
index = 0;
|
|
} else if (index > sidebarLength - 1) {
|
|
index = sidebarLength - 1;
|
|
}
|
|
this.scrollToAnchor(index);
|
|
},
|
|
onTouchStop: function () {
|
|
this.scrollToAnchorIndex = null;
|
|
},
|
|
scrollToAnchor: function (index) {
|
|
var _this = this;
|
|
if (typeof index !== 'number' || this.scrollToAnchorIndex === index) {
|
|
return;
|
|
}
|
|
this.scrollToAnchorIndex = index;
|
|
var anchor = this.children.find(function (item) {
|
|
return item.data.index === _this.data.indexList[index];
|
|
});
|
|
if (anchor) {
|
|
anchor.scrollIntoView(this.scrollTop);
|
|
this.$emit('select', anchor.data.index);
|
|
}
|
|
},
|
|
},
|
|
});
|