'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
var component_1 = require('../common/component');
var color_1 = require('../common/color');
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.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 anchor
            .getRect('.van-index-anchor-wrapper')
            .then(function (rect) {
              Object.assign(anchor, {
                height: rect.height,
                top: rect.top + _this.scrollTop,
              });
            });
        })
      );
    },
    setListRect: function () {
      var _this = this;
      return this.getRect('.van-index-bar').then(function (rect) {
        Object.assign(_this, {
          height: rect.height,
          top: rect.top + _this.scrollTop,
        });
      });
    },
    setSiderbarRect: function () {
      var _this = this;
      return this.getRect('.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 anchor.getRect('.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);
      }
    },
  },
});