| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308 | "use strict";Object.defineProperty(exports, "__esModule", { value: true });var component_1 = require("../common/component");var touch_1 = require("../mixins/touch");var utils_1 = require("../common/utils");component_1.VantComponent({    mixins: [touch_1.touch],    classes: ['nav-class', 'tab-class', 'tab-active-class', 'line-class'],    relation: {        name: 'tab',        type: 'descendant',        linked: function (child) {            this.child.push(child);            this.updateTabs(this.data.tabs.concat(child.data));        },        unlinked: function (child) {            var index = this.child.indexOf(child);            var tabs = this.data.tabs;            tabs.splice(index, 1);            this.child.splice(index, 1);            this.updateTabs(tabs);        }    },    props: {        color: String,        sticky: Boolean,        animated: Boolean,        swipeable: Boolean,        lineWidth: {            type: Number,            value: -1        },        lineHeight: {            type: Number,            value: -1        },        active: {            type: Number,            value: 0        },        type: {            type: String,            value: 'line'        },        border: {            type: Boolean,            value: true        },        duration: {            type: Number,            value: 0.3        },        zIndex: {            type: Number,            value: 1        },        swipeThreshold: {            type: Number,            value: 4        },        offsetTop: {            type: Number,            value: 0        }    },    data: {        tabs: [],        lineStyle: '',        scrollLeft: 0,        scrollable: false,        trackStyle: '',        wrapStyle: '',        position: ''    },    watch: {        swipeThreshold: function () {            this.set({                scrollable: this.child.length > this.data.swipeThreshold            });        },        color: 'setLine',        lineWidth: 'setLine',        lineHeight: 'setLine',        active: 'setActiveTab',        animated: 'setTrack',        offsetTop: 'setWrapStyle'    },    beforeCreate: function () {        this.child = [];    },    mounted: function () {        var _this = this;        this.setLine(true);        this.setTrack();        this.scrollIntoView();        this.getRect('.van-tabs__wrap').then(function (rect) {            _this.navHeight = rect.height;            _this.observerContentScroll();        });    },    destroyed: function () {        // @ts-ignore        this.createIntersectionObserver().disconnect();    },    methods: {        updateTabs: function (tabs) {            tabs = tabs || this.data.tabs;            this.set({                tabs: tabs,                scrollable: tabs.length > this.data.swipeThreshold            });            this.setActiveTab();        },        trigger: function (eventName, index) {            this.$emit(eventName, {                index: index,                title: this.data.tabs[index].title            });        },        onTap: function (event) {            var index = event.currentTarget.dataset.index;            if (this.data.tabs[index].disabled) {                this.trigger('disabled', index);            }            else {                this.trigger('click', index);                this.setActive(index);            }        },        setActive: function (active) {            if (active !== this.data.active) {                this.trigger('change', active);                this.set({ active: active });                this.setActiveTab();            }        },        setLine: function (skipTransition) {            var _this = this;            if (this.data.type !== 'line') {                return;            }            var _a = this.data, color = _a.color, active = _a.active, duration = _a.duration, lineWidth = _a.lineWidth, lineHeight = _a.lineHeight;            this.getRect('.van-tab', true).then(function (rects) {                var rect = rects[active];                var width = lineWidth !== -1 ? lineWidth : rect.width / 2;                var height = lineHeight !== -1 ? "height: " + lineHeight + "px;" : '';                var left = rects                    .slice(0, active)                    .reduce(function (prev, curr) { return prev + curr.width; }, 0);                left += (rect.width - width) / 2;                var transition = skipTransition                    ? ''                    : "transition-duration: " + duration + "s; -webkit-transition-duration: " + duration + "s;";                _this.set({                    lineStyle: "\n            " + height + "\n            width: " + width + "px;\n            background-color: " + color + ";\n            -webkit-transform: translateX(" + left + "px);\n            transform: translateX(" + left + "px);\n            " + transition + "\n          "                });            });        },        setTrack: function () {            var _this = this;            var _a = this.data, animated = _a.animated, active = _a.active, duration = _a.duration;            if (!animated)                return '';            this.getRect('.van-tabs__content').then(function (rect) {                var width = rect.width;                _this.set({                    trackStyle: "\n            width: " + width * _this.child.length + "px;\n            left: " + -1 * active * width + "px;\n            transition: left " + duration + "s;\n            display: -webkit-box;\n            display: flex;\n          "                });                var props = { width: width, animated: animated };                _this.child.forEach(function (item) {                    item.set(props);                });            });        },        setActiveTab: function () {            var _this = this;            this.child.forEach(function (item, index) {                var data = {                    active: index === _this.data.active                };                if (data.active) {                    data.inited = true;                }                if (data.active !== item.data.active) {                    item.set(data);                }            });            utils_1.nextTick(function () {                _this.setLine();                _this.setTrack();                _this.scrollIntoView();            });        },        // scroll active tab into view        scrollIntoView: function () {            var _this = this;            var _a = this.data, active = _a.active, scrollable = _a.scrollable;            if (!scrollable) {                return;            }            Promise.all([                this.getRect('.van-tab', true),                this.getRect('.van-tabs__nav')            ]).then(function (_a) {                var tabRects = _a[0], navRect = _a[1];                var tabRect = tabRects[active];                var offsetLeft = tabRects                    .slice(0, active)                    .reduce(function (prev, curr) { return prev + curr.width; }, 0);                _this.set({                    scrollLeft: offsetLeft - (navRect.width - tabRect.width) / 2                });            });        },        onTouchStart: function (event) {            if (!this.data.swipeable)                return;            this.touchStart(event);        },        onTouchMove: function (event) {            if (!this.data.swipeable)                return;            this.touchMove(event);        },        // watch swipe touch end        onTouchEnd: function () {            if (!this.data.swipeable)                return;            var _a = this.data, active = _a.active, tabs = _a.tabs;            var _b = this, direction = _b.direction, deltaX = _b.deltaX, offsetX = _b.offsetX;            var minSwipeDistance = 50;            if (direction === 'horizontal' && offsetX >= minSwipeDistance) {                if (deltaX > 0 && active !== 0) {                    this.setActive(active - 1);                }                else if (deltaX < 0 && active !== tabs.length - 1) {                    this.setActive(active + 1);                }            }        },        setWrapStyle: function () {            var _a = this.data, offsetTop = _a.offsetTop, position = _a.position;            var wrapStyle;            switch (position) {                case 'top':                    wrapStyle = "\n            top: " + offsetTop + "px;\n            position: fixed;\n          ";                    break;                case 'bottom':                    wrapStyle = "\n            top: auto;\n            bottom: 0;\n          ";                    break;                default:                    wrapStyle = '';            }            // cut down `set`            if (wrapStyle === this.data.wrapStyle)                return;            this.set({ wrapStyle: wrapStyle });        },        observerContentScroll: function () {            var _this = this;            if (!this.data.sticky) {                return;            }            var offsetTop = this.data.offsetTop;            var windowHeight = wx.getSystemInfoSync().windowHeight;            // @ts-ignore            this.createIntersectionObserver().disconnect();            // @ts-ignore            this.createIntersectionObserver()                .relativeToViewport({ top: -(this.navHeight + offsetTop) })                .observe('.van-tabs', function (res) {                var top = res.boundingClientRect.top;                if (top > offsetTop) {                    return;                }                var position = res.intersectionRatio > 0 ? 'top' : 'bottom';                _this.$emit('scroll', {                    scrollTop: top + offsetTop,                    isFixed: position === 'top'                });                _this.setPosition(position);            });            // @ts-ignore            this.createIntersectionObserver()                .relativeToViewport({ bottom: -(windowHeight - 1 - offsetTop) })                .observe('.van-tabs', function (res) {                var _a = res.boundingClientRect, top = _a.top, bottom = _a.bottom;                if (bottom < _this.navHeight) {                    return;                }                var position = res.intersectionRatio > 0 ? 'top' : '';                _this.$emit('scroll', {                    scrollTop: top + offsetTop,                    isFixed: position === 'top'                });                _this.setPosition(position);            });        },        setPosition: function (position) {            var _this = this;            if (position !== this.data.position) {                this.set({ position: position }).then(function () {                    _this.setWrapStyle();                });            }        }    }});
 |