1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
| <template>
| <uni-shadow-root class="vant-dropdown-menu-index"><view class="van-dropdown-menu van-dropdown-menu--top-bottom">
| <view v-for="(item,index) in (itemListData)" :key="item.index" :data-index="index" :class="utils.bem('dropdown-menu__item', { disabled: item.disabled })" @click="onTitleTap">
| <view :class="(item.titleClass)+' '+(utils.bem('dropdown-menu__title', { active: item.showPopup, down: item.showPopup === (direction === 'down') }))" :style="item.showPopup ? 'color:' + activeColor : ''">
| <view class="van-ellipsis">
| {{ computed.displayTitle(item) }}
| </view>
| </view>
| </view>
|
| <slot></slot>
| </view></uni-shadow-root>
| </template>
| <wxs src="../wxs/utils.wxs" module="utils"></wxs><wxs src="./index.wxs" module="computed"></wxs>
| <script>
|
| global['__wxRoute'] = 'vant/dropdown-menu/index'
| import { VantComponent } from '../common/component';
| import { addUnit } from '../common/utils';
| let ARRAY = [];
| VantComponent({
| field: true,
| relation: {
| name: 'dropdown-item',
| type: 'descendant',
| current: 'dropdown-menu',
| linked() {
| this.updateItemListData();
| },
| unlinked() {
| this.updateItemListData();
| },
| },
| props: {
| activeColor: {
| type: String,
| observer: 'updateChildrenData',
| },
| overlay: {
| type: Boolean,
| value: true,
| observer: 'updateChildrenData',
| },
| zIndex: {
| type: Number,
| value: 10,
| },
| duration: {
| type: Number,
| value: 200,
| observer: 'updateChildrenData',
| },
| direction: {
| type: String,
| value: 'down',
| observer: 'updateChildrenData',
| },
| closeOnClickOverlay: {
| type: Boolean,
| value: true,
| observer: 'updateChildrenData',
| },
| closeOnClickOutside: {
| type: Boolean,
| value: true,
| },
| },
| data: {
| itemListData: [],
| },
| beforeCreate() {
| const { windowHeight } = wx.getSystemInfoSync();
| this.windowHeight = windowHeight;
| ARRAY.push(this);
| },
| destroyed() {
| ARRAY = ARRAY.filter((item) => item !== this);
| },
| methods: {
| updateItemListData() {
| this.setData({
| itemListData: this.children.map((child) => child.data),
| });
| },
| updateChildrenData() {
| this.children.forEach((child) => {
| child.updateDataFromParent();
| });
| },
| toggleItem(active) {
| this.children.forEach((item, index) => {
| const { showPopup } = item.data;
| if (index === active) {
| item.toggle();
| } else if (showPopup) {
| item.toggle(false, { immediate: true });
| }
| });
| },
| close() {
| this.children.forEach((child) => {
| child.toggle(false, { immediate: true });
| });
| },
| getChildWrapperStyle() {
| const { zIndex, direction } = this.data;
| return this.getRect('.van-dropdown-menu').then((rect) => {
| const { top = 0, bottom = 0 } = rect;
| const offset = direction === 'down' ? bottom : this.windowHeight - top;
| let wrapperStyle = `z-index: ${zIndex};`;
| if (direction === 'down') {
| wrapperStyle += `top: ${addUnit(offset)};`;
| } else {
| wrapperStyle += `bottom: ${addUnit(offset)};`;
| }
| return wrapperStyle;
| });
| },
| onTitleTap(event) {
| const { index } = event.currentTarget.dataset;
| const child = this.children[index];
| if (!child.data.disabled) {
| ARRAY.forEach((menuItem) => {
| if (
| menuItem &&
| menuItem.data.closeOnClickOutside &&
| menuItem !== this
| ) {
| menuItem.close();
| }
| });
| this.toggleItem(index);
| }
| },
| },
| });
| export default global['__wxComponents']['vant/dropdown-menu/index']
| </script>
| <style platform="mp-weixin">
| @import '../common/index.css';.van-dropdown-menu{display:-webkit-flex;display:flex;-webkit-user-select:none;user-select:none;height:50px;height:var(--dropdown-menu-height,50px);background-color:#fff;background-color:var(--dropdown-menu-background-color,#fff)}.van-dropdown-menu__item{display:-webkit-flex;display:flex;-webkit-flex:1;flex:1;-webkit-align-items:center;align-items:center;-webkit-justify-content:center;justify-content:center;min-width:0}.van-dropdown-menu__item:active{opacity:.7}.van-dropdown-menu__item--disabled:active{opacity:1}.van-dropdown-menu__item--disabled .van-dropdown-menu__title{color:#969799;color:var(--dropdown-menu-title-disabled-text-color,#969799)}.van-dropdown-menu__title{position:relative;box-sizing:border-box;max-width:100%;padding:0 8px;padding:var(--dropdown-menu-title-padding,0 8px);color:#323233;color:var(--dropdown-menu-title-text-color,#323233);font-size:15px;font-size:var(--dropdown-menu-title-font-size,15px);line-height:18px;line-height:var(--dropdown-menu-title-line-height,18px)}.van-dropdown-menu__title:after{position:absolute;top:50%;right:-4px;margin-top:-5px;border-color:transparent transparent currentcolor currentcolor;border-style:solid;border-width:3px;-webkit-transform:rotate(-45deg);transform:rotate(-45deg);opacity:.8;content:""}.van-dropdown-menu__title--active{color:#1989fa;color:var(--dropdown-menu-title-active-text-color,#1989fa)}.van-dropdown-menu__title--down:after{margin-top:-1px;-webkit-transform:rotate(135deg);transform:rotate(135deg)}
| </style>
|
|