12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- <template>
- <view class="van-sidebar custom-class">
- <slot />
- </view>
- </template>
- <script>
- 'use strict';
- Object.defineProperty(exports, '__esModule', {
- value: true
- });
- var component_1 = require('../common/component');
- component_1.VantComponent({
- relation: {
- name: 'sidebar-item',
- type: 'descendant',
- current: 'sidebar',
- linked: function () {
- this.setActive(this.activeKey);
- },
- unlinked: function () {
- this.setActive(this.activeKey);
- }
- },
- props: {
- activeKey: {
- type: Number,
- value: 0,
- observer: 'setActive'
- }
- },
- beforeCreate: function () {
- this.currentActive = -1;
- },
- methods: {
- setActive: function (activeKey) {
- var that = this;
- var children = that.children;
- var currentActive = that.currentActive;
- if (!children.length) {
- return Promise.resolve();
- }
- this.currentActive = activeKey;
- var stack = [];
- if (currentActive !== activeKey && children[currentActive]) {
- stack.push(children[currentActive].setActive(false));
- }
- if (children[activeKey]) {
- stack.push(children[activeKey].setActive(true));
- }
- return Promise.all(stack);
- }
- }
- });
- </script>
- <style>
- @import './index.css';
- </style>
|