@netang/quasar 0.1.42 → 0.1.43
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/drawer/index.vue +303 -303
- package/components/field-tree/index.vue +9 -12
- package/components/toolbar/index.vue +138 -136
- package/package.json +1 -1
- package/utils/$search.js +416 -0
- package/utils/$table.js +3 -3
- package/utils/index.js +3 -0
|
@@ -1,303 +1,303 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<q-drawer
|
|
3
|
-
v-model="currentModelValue"
|
|
4
|
-
:side="side"
|
|
5
|
-
:breakpoint="breakpoint"
|
|
6
|
-
:width="currentWidth"
|
|
7
|
-
v-bind="$attrs"
|
|
8
|
-
>
|
|
9
|
-
<!-- 插槽 -->
|
|
10
|
-
<slot />
|
|
11
|
-
|
|
12
|
-
<!-- 拖拽手柄 -->
|
|
13
|
-
<div
|
|
14
|
-
class="n-drawer__drag-handle"
|
|
15
|
-
:class="`n-drawer__drag-handle--${side}`"
|
|
16
|
-
v-touch-pan.horizontal.prevent.mouse.preserveCursor="onTouchPan"
|
|
17
|
-
v-if="! $q.platform.is.mobile && drag"
|
|
18
|
-
></div>
|
|
19
|
-
</q-drawer>
|
|
20
|
-
</template>
|
|
21
|
-
|
|
22
|
-
<script>
|
|
23
|
-
import { ref, inject, nextTick, watch } from 'vue'
|
|
24
|
-
import { useQuasar } from 'quasar'
|
|
25
|
-
|
|
26
|
-
import $n_isNil from 'lodash/isNil'
|
|
27
|
-
|
|
28
|
-
import $n_router from '@netang/utils/vue/router'
|
|
29
|
-
|
|
30
|
-
import $n_storage from '@netang/utils/storage'
|
|
31
|
-
import $n_sleep from '@netang/utils/sleep'
|
|
32
|
-
import $n_percentValue from '@netang/utils/percentValue'
|
|
33
|
-
import $n_pxValue from '@netang/utils/pxValue'
|
|
34
|
-
|
|
35
|
-
import { layoutKey, emptyRenderFn } from 'quasar/src/utils/private/symbols.js'
|
|
36
|
-
|
|
37
|
-
import { NPowerKey } from '../../utils/symbols'
|
|
38
|
-
|
|
39
|
-
export default {
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* 标识
|
|
43
|
-
*/
|
|
44
|
-
name: 'NDrawer',
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* 声明属性
|
|
48
|
-
*/
|
|
49
|
-
props: {
|
|
50
|
-
// 值
|
|
51
|
-
modelValue: Boolean,
|
|
52
|
-
// 位置
|
|
53
|
-
side: {
|
|
54
|
-
type: String,
|
|
55
|
-
default: 'left',
|
|
56
|
-
validator: v => [ 'left', 'right' ].includes(v)
|
|
57
|
-
},
|
|
58
|
-
// 宽度
|
|
59
|
-
width: {
|
|
60
|
-
type: Number,
|
|
61
|
-
default: 300
|
|
62
|
-
},
|
|
63
|
-
breakpoint: {
|
|
64
|
-
type: Number,
|
|
65
|
-
default: 1000,
|
|
66
|
-
},
|
|
67
|
-
|
|
68
|
-
// 【自定义属性】
|
|
69
|
-
// --------------------------------------------------
|
|
70
|
-
// 手机端宽度(px / %)
|
|
71
|
-
mobileWidth: {
|
|
72
|
-
type: [String, Number],
|
|
73
|
-
default: '80%',
|
|
74
|
-
},
|
|
75
|
-
// 最小宽度
|
|
76
|
-
minWidth: {
|
|
77
|
-
type: Number,
|
|
78
|
-
default: 100,
|
|
79
|
-
},
|
|
80
|
-
// 最大宽度
|
|
81
|
-
maxWidth: Number,
|
|
82
|
-
// 是否可拖拽
|
|
83
|
-
drag: Boolean,
|
|
84
|
-
// 是否拖拽折叠
|
|
85
|
-
// dragCollapse: Boolean,
|
|
86
|
-
// 折叠宽度
|
|
87
|
-
// collapseWidth: {
|
|
88
|
-
// type: Number,
|
|
89
|
-
// default: 80,
|
|
90
|
-
// },
|
|
91
|
-
// 缓存名
|
|
92
|
-
cache: [Boolean, String],
|
|
93
|
-
},
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* 声明事件
|
|
97
|
-
*/
|
|
98
|
-
emits: [
|
|
99
|
-
'update:modelValue',
|
|
100
|
-
],
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* 组合式
|
|
104
|
-
*/
|
|
105
|
-
setup(props, { emit }) {
|
|
106
|
-
|
|
107
|
-
// ==========【数据】============================================================================================
|
|
108
|
-
|
|
109
|
-
// 获取 quasar 注入
|
|
110
|
-
const $quasarLayout = inject(layoutKey, emptyRenderFn)
|
|
111
|
-
if ($quasarLayout === emptyRenderFn) {
|
|
112
|
-
console.error('NDrawer needs to be child of QLayout')
|
|
113
|
-
return emptyRenderFn
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
// quasar 对象
|
|
117
|
-
const $q = useQuasar()
|
|
118
|
-
|
|
119
|
-
// 获取权限注入数据
|
|
120
|
-
const $power = inject(NPowerKey)
|
|
121
|
-
|
|
122
|
-
// 是否显示
|
|
123
|
-
let currentModelValue
|
|
124
|
-
if ($power) {
|
|
125
|
-
currentModelValue = $power[`${props.side}Drawer`].modelValue
|
|
126
|
-
if ($q.screen.width < props.breakpoint) {
|
|
127
|
-
currentModelValue.value = false
|
|
128
|
-
emit('update:modelValue', false)
|
|
129
|
-
} else {
|
|
130
|
-
currentModelValue.value = props.modelValue
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
} else {
|
|
134
|
-
currentModelValue = ref(props.modelValue)
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// 创建睡眠实例
|
|
138
|
-
const sleep = $n_sleep()
|
|
139
|
-
|
|
140
|
-
// 缓存名
|
|
141
|
-
let cacheName = ''
|
|
142
|
-
|
|
143
|
-
// 获取原始宽度
|
|
144
|
-
let originalWidth = props.width
|
|
145
|
-
|
|
146
|
-
// 如果是手机端
|
|
147
|
-
if ($q.platform.is.mobile) {
|
|
148
|
-
|
|
149
|
-
// 获取手机端百分比值
|
|
150
|
-
let res = $n_percentValue(props.mobileWidth, true)
|
|
151
|
-
|
|
152
|
-
// 如果是百分比值
|
|
153
|
-
if (! $n_isNil(res)) {
|
|
154
|
-
// 原始尺寸 = 屏幕宽度 * 百分比
|
|
155
|
-
if (res) {
|
|
156
|
-
originalWidth = $q.screen.width * res
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
} else {
|
|
160
|
-
// 原始尺寸 = 屏幕宽度像素
|
|
161
|
-
res = $n_pxValue(props.mobileWidth)
|
|
162
|
-
if (res) {
|
|
163
|
-
originalWidth = res
|
|
164
|
-
}
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
// 否则如果开启拖拽 && 开启缓存
|
|
168
|
-
} else if (props.drag && props.cache) {
|
|
169
|
-
|
|
170
|
-
// 设置缓存名
|
|
171
|
-
cacheName = `drawer:${props.side}:${props.cache === true ? ($power && $power.routePath ? $power.routePath : $n_router.getRoute('path')) : props.cache}`
|
|
172
|
-
|
|
173
|
-
// 从缓存获取宽度
|
|
174
|
-
const cache = $n_storage.get(cacheName)
|
|
175
|
-
if (cache) {
|
|
176
|
-
originalWidth = cache
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// 当前宽度
|
|
181
|
-
const currentWidth = ref(originalWidth)
|
|
182
|
-
|
|
183
|
-
// 下次 DOM 更新
|
|
184
|
-
nextTick(function() {
|
|
185
|
-
if (currentModelValue.value && $quasarLayout.totalWidth.value < props.breakpoint) {
|
|
186
|
-
currentModelValue.value = false
|
|
187
|
-
}
|
|
188
|
-
})
|
|
189
|
-
|
|
190
|
-
// ==========【监听数据】==========================================================================================
|
|
191
|
-
|
|
192
|
-
/**
|
|
193
|
-
* 监听声明值
|
|
194
|
-
*/
|
|
195
|
-
watch(()=>props.modelValue, function (val) {
|
|
196
|
-
currentModelValue.value = val
|
|
197
|
-
})
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* 监听当前值
|
|
201
|
-
*/
|
|
202
|
-
watch(currentModelValue, function (val) {
|
|
203
|
-
emit('update:modelValue', val)
|
|
204
|
-
})
|
|
205
|
-
|
|
206
|
-
// ==========【方法】=============================================================================================
|
|
207
|
-
|
|
208
|
-
/**
|
|
209
|
-
* 拖动事件
|
|
210
|
-
*/
|
|
211
|
-
let initialWidth
|
|
212
|
-
function onTouchPan({ isFirst, offset: { x } }) {
|
|
213
|
-
|
|
214
|
-
// 设置初始宽度
|
|
215
|
-
if (isFirst === true) {
|
|
216
|
-
initialWidth = currentWidth.value
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
// 获取拖拽宽度
|
|
220
|
-
let dragWidth = initialWidth + (props.side === 'left' ? + x : - x)
|
|
221
|
-
let newWidth = dragWidth
|
|
222
|
-
|
|
223
|
-
// 如果宽度 < 最小宽度
|
|
224
|
-
if (props.minWidth && newWidth < props.minWidth) {
|
|
225
|
-
newWidth = props.minWidth
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
// 如果宽度 > 最大宽度
|
|
229
|
-
if (props.maxWidth && newWidth > props.maxWidth) {
|
|
230
|
-
newWidth = props.maxWidth
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
// if (
|
|
234
|
-
// // 如果显示
|
|
235
|
-
// currentModelValue.value
|
|
236
|
-
// // 如果开启折叠
|
|
237
|
-
// && props.dragCollapse
|
|
238
|
-
// // 如果有最小宽度
|
|
239
|
-
// && props.minWidth
|
|
240
|
-
// ) {
|
|
241
|
-
// const collapseWidth = props.collapseWidth < props.minWidth ? props.collapseWidth : props.minWidth - 10
|
|
242
|
-
//
|
|
243
|
-
// // 如果 拖拽宽度 < 折叠宽度
|
|
244
|
-
// if (dragWidth < collapseWidth) {
|
|
245
|
-
// currentModelValue.value = false
|
|
246
|
-
// }
|
|
247
|
-
// }
|
|
248
|
-
|
|
249
|
-
// 设置当前宽度
|
|
250
|
-
currentWidth.value = newWidth
|
|
251
|
-
|
|
252
|
-
// 如果开启缓存
|
|
253
|
-
if (props.drag && props.cache && cacheName) {
|
|
254
|
-
|
|
255
|
-
// 延迟执行
|
|
256
|
-
sleep(500)
|
|
257
|
-
.then(function () {
|
|
258
|
-
// 设置缓存(永久缓存)
|
|
259
|
-
$n_storage.set(cacheName, newWidth, 0)
|
|
260
|
-
})
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
|
|
264
|
-
// ==========【返回】=============================================================================================
|
|
265
|
-
|
|
266
|
-
return {
|
|
267
|
-
// 是否显示
|
|
268
|
-
currentModelValue,
|
|
269
|
-
// 当前宽度
|
|
270
|
-
currentWidth,
|
|
271
|
-
|
|
272
|
-
// 拖动事件
|
|
273
|
-
onTouchPan,
|
|
274
|
-
}
|
|
275
|
-
},
|
|
276
|
-
}
|
|
277
|
-
</script>
|
|
278
|
-
|
|
279
|
-
<style lang="scss" scoped>
|
|
280
|
-
.n-drawer {
|
|
281
|
-
// 拖拽手柄
|
|
282
|
-
&__drag-handle {
|
|
283
|
-
position: absolute;
|
|
284
|
-
top: 0;
|
|
285
|
-
bottom: 0;
|
|
286
|
-
width: 10px;
|
|
287
|
-
cursor: e-resize;
|
|
288
|
-
user-select: none;
|
|
289
|
-
z-index: 10;
|
|
290
|
-
right: 0;
|
|
291
|
-
|
|
292
|
-
// 左边侧滑菜单
|
|
293
|
-
&--left {
|
|
294
|
-
right: -5px;
|
|
295
|
-
}
|
|
296
|
-
|
|
297
|
-
// 右边侧滑菜单
|
|
298
|
-
&--right {
|
|
299
|
-
left: -5px;
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
</style>
|
|
1
|
+
<template>
|
|
2
|
+
<q-drawer
|
|
3
|
+
v-model="currentModelValue"
|
|
4
|
+
:side="side"
|
|
5
|
+
:breakpoint="breakpoint"
|
|
6
|
+
:width="currentWidth"
|
|
7
|
+
v-bind="$attrs"
|
|
8
|
+
>
|
|
9
|
+
<!-- 插槽 -->
|
|
10
|
+
<slot />
|
|
11
|
+
|
|
12
|
+
<!-- 拖拽手柄 -->
|
|
13
|
+
<div
|
|
14
|
+
class="n-drawer__drag-handle"
|
|
15
|
+
:class="`n-drawer__drag-handle--${side}`"
|
|
16
|
+
v-touch-pan.horizontal.prevent.mouse.preserveCursor="onTouchPan"
|
|
17
|
+
v-if="! $q.platform.is.mobile && drag"
|
|
18
|
+
></div>
|
|
19
|
+
</q-drawer>
|
|
20
|
+
</template>
|
|
21
|
+
|
|
22
|
+
<script>
|
|
23
|
+
import { ref, inject, nextTick, watch } from 'vue'
|
|
24
|
+
import { useQuasar } from 'quasar'
|
|
25
|
+
|
|
26
|
+
import $n_isNil from 'lodash/isNil'
|
|
27
|
+
|
|
28
|
+
import $n_router from '@netang/utils/vue/router'
|
|
29
|
+
|
|
30
|
+
import $n_storage from '@netang/utils/storage'
|
|
31
|
+
import $n_sleep from '@netang/utils/sleep'
|
|
32
|
+
import $n_percentValue from '@netang/utils/percentValue'
|
|
33
|
+
import $n_pxValue from '@netang/utils/pxValue'
|
|
34
|
+
|
|
35
|
+
import { layoutKey, emptyRenderFn } from 'quasar/src/utils/private/symbols.js'
|
|
36
|
+
|
|
37
|
+
import { NPowerKey } from '../../utils/symbols'
|
|
38
|
+
|
|
39
|
+
export default {
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* 标识
|
|
43
|
+
*/
|
|
44
|
+
name: 'NDrawer',
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* 声明属性
|
|
48
|
+
*/
|
|
49
|
+
props: {
|
|
50
|
+
// 值
|
|
51
|
+
modelValue: Boolean,
|
|
52
|
+
// 位置
|
|
53
|
+
side: {
|
|
54
|
+
type: String,
|
|
55
|
+
default: 'left',
|
|
56
|
+
validator: v => [ 'left', 'right' ].includes(v)
|
|
57
|
+
},
|
|
58
|
+
// 宽度
|
|
59
|
+
width: {
|
|
60
|
+
type: Number,
|
|
61
|
+
default: 300
|
|
62
|
+
},
|
|
63
|
+
breakpoint: {
|
|
64
|
+
type: Number,
|
|
65
|
+
default: 1000,
|
|
66
|
+
},
|
|
67
|
+
|
|
68
|
+
// 【自定义属性】
|
|
69
|
+
// --------------------------------------------------
|
|
70
|
+
// 手机端宽度(px / %)
|
|
71
|
+
mobileWidth: {
|
|
72
|
+
type: [String, Number],
|
|
73
|
+
default: '80%',
|
|
74
|
+
},
|
|
75
|
+
// 最小宽度
|
|
76
|
+
minWidth: {
|
|
77
|
+
type: Number,
|
|
78
|
+
default: 100,
|
|
79
|
+
},
|
|
80
|
+
// 最大宽度
|
|
81
|
+
maxWidth: Number,
|
|
82
|
+
// 是否可拖拽
|
|
83
|
+
drag: Boolean,
|
|
84
|
+
// 是否拖拽折叠
|
|
85
|
+
// dragCollapse: Boolean,
|
|
86
|
+
// 折叠宽度
|
|
87
|
+
// collapseWidth: {
|
|
88
|
+
// type: Number,
|
|
89
|
+
// default: 80,
|
|
90
|
+
// },
|
|
91
|
+
// 缓存名
|
|
92
|
+
cache: [Boolean, String],
|
|
93
|
+
},
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* 声明事件
|
|
97
|
+
*/
|
|
98
|
+
emits: [
|
|
99
|
+
'update:modelValue',
|
|
100
|
+
],
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* 组合式
|
|
104
|
+
*/
|
|
105
|
+
setup(props, { emit }) {
|
|
106
|
+
|
|
107
|
+
// ==========【数据】============================================================================================
|
|
108
|
+
|
|
109
|
+
// 获取 quasar 注入
|
|
110
|
+
const $quasarLayout = inject(layoutKey, emptyRenderFn)
|
|
111
|
+
if ($quasarLayout === emptyRenderFn) {
|
|
112
|
+
console.error('NDrawer needs to be child of QLayout')
|
|
113
|
+
return emptyRenderFn
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
// quasar 对象
|
|
117
|
+
const $q = useQuasar()
|
|
118
|
+
|
|
119
|
+
// 获取权限注入数据
|
|
120
|
+
const $power = inject(NPowerKey)
|
|
121
|
+
|
|
122
|
+
// 是否显示
|
|
123
|
+
let currentModelValue
|
|
124
|
+
if ($power) {
|
|
125
|
+
currentModelValue = $power[`${props.side}Drawer`].modelValue
|
|
126
|
+
if ($q.screen.width < props.breakpoint) {
|
|
127
|
+
currentModelValue.value = false
|
|
128
|
+
emit('update:modelValue', false)
|
|
129
|
+
} else {
|
|
130
|
+
currentModelValue.value = props.modelValue
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
} else {
|
|
134
|
+
currentModelValue = ref(props.modelValue)
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// 创建睡眠实例
|
|
138
|
+
const sleep = $n_sleep()
|
|
139
|
+
|
|
140
|
+
// 缓存名
|
|
141
|
+
let cacheName = ''
|
|
142
|
+
|
|
143
|
+
// 获取原始宽度
|
|
144
|
+
let originalWidth = props.width
|
|
145
|
+
|
|
146
|
+
// 如果是手机端
|
|
147
|
+
if ($q.platform.is.mobile) {
|
|
148
|
+
|
|
149
|
+
// 获取手机端百分比值
|
|
150
|
+
let res = $n_percentValue(props.mobileWidth, true)
|
|
151
|
+
|
|
152
|
+
// 如果是百分比值
|
|
153
|
+
if (! $n_isNil(res)) {
|
|
154
|
+
// 原始尺寸 = 屏幕宽度 * 百分比
|
|
155
|
+
if (res) {
|
|
156
|
+
originalWidth = $q.screen.width * res
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
} else {
|
|
160
|
+
// 原始尺寸 = 屏幕宽度像素
|
|
161
|
+
res = $n_pxValue(props.mobileWidth)
|
|
162
|
+
if (res) {
|
|
163
|
+
originalWidth = res
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// 否则如果开启拖拽 && 开启缓存
|
|
168
|
+
} else if (props.drag && props.cache) {
|
|
169
|
+
|
|
170
|
+
// 设置缓存名
|
|
171
|
+
cacheName = `drawer:${props.side}:${props.cache === true ? ($power && $power.routePath ? $power.routePath : $n_router.getRoute('path')) : props.cache}`
|
|
172
|
+
|
|
173
|
+
// 从缓存获取宽度
|
|
174
|
+
const cache = $n_storage.get(cacheName)
|
|
175
|
+
if (cache) {
|
|
176
|
+
originalWidth = cache
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
// 当前宽度
|
|
181
|
+
const currentWidth = ref(originalWidth)
|
|
182
|
+
|
|
183
|
+
// 下次 DOM 更新
|
|
184
|
+
nextTick(function() {
|
|
185
|
+
if (currentModelValue.value && $quasarLayout.totalWidth.value < props.breakpoint) {
|
|
186
|
+
currentModelValue.value = false
|
|
187
|
+
}
|
|
188
|
+
})
|
|
189
|
+
|
|
190
|
+
// ==========【监听数据】==========================================================================================
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* 监听声明值
|
|
194
|
+
*/
|
|
195
|
+
watch(()=>props.modelValue, function (val) {
|
|
196
|
+
currentModelValue.value = val
|
|
197
|
+
})
|
|
198
|
+
|
|
199
|
+
/**
|
|
200
|
+
* 监听当前值
|
|
201
|
+
*/
|
|
202
|
+
watch(currentModelValue, function (val) {
|
|
203
|
+
emit('update:modelValue', val)
|
|
204
|
+
})
|
|
205
|
+
|
|
206
|
+
// ==========【方法】=============================================================================================
|
|
207
|
+
|
|
208
|
+
/**
|
|
209
|
+
* 拖动事件
|
|
210
|
+
*/
|
|
211
|
+
let initialWidth
|
|
212
|
+
function onTouchPan({ isFirst, offset: { x } }) {
|
|
213
|
+
|
|
214
|
+
// 设置初始宽度
|
|
215
|
+
if (isFirst === true) {
|
|
216
|
+
initialWidth = currentWidth.value
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
// 获取拖拽宽度
|
|
220
|
+
let dragWidth = initialWidth + (props.side === 'left' ? + x : - x)
|
|
221
|
+
let newWidth = dragWidth
|
|
222
|
+
|
|
223
|
+
// 如果宽度 < 最小宽度
|
|
224
|
+
if (props.minWidth && newWidth < props.minWidth) {
|
|
225
|
+
newWidth = props.minWidth
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
// 如果宽度 > 最大宽度
|
|
229
|
+
if (props.maxWidth && newWidth > props.maxWidth) {
|
|
230
|
+
newWidth = props.maxWidth
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
// if (
|
|
234
|
+
// // 如果显示
|
|
235
|
+
// currentModelValue.value
|
|
236
|
+
// // 如果开启折叠
|
|
237
|
+
// && props.dragCollapse
|
|
238
|
+
// // 如果有最小宽度
|
|
239
|
+
// && props.minWidth
|
|
240
|
+
// ) {
|
|
241
|
+
// const collapseWidth = props.collapseWidth < props.minWidth ? props.collapseWidth : props.minWidth - 10
|
|
242
|
+
//
|
|
243
|
+
// // 如果 拖拽宽度 < 折叠宽度
|
|
244
|
+
// if (dragWidth < collapseWidth) {
|
|
245
|
+
// currentModelValue.value = false
|
|
246
|
+
// }
|
|
247
|
+
// }
|
|
248
|
+
|
|
249
|
+
// 设置当前宽度
|
|
250
|
+
currentWidth.value = newWidth
|
|
251
|
+
|
|
252
|
+
// 如果开启缓存
|
|
253
|
+
if (props.drag && props.cache && cacheName) {
|
|
254
|
+
|
|
255
|
+
// 延迟执行
|
|
256
|
+
sleep(500)
|
|
257
|
+
.then(function () {
|
|
258
|
+
// 设置缓存(永久缓存)
|
|
259
|
+
$n_storage.set(cacheName, newWidth, 0)
|
|
260
|
+
})
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
// ==========【返回】=============================================================================================
|
|
265
|
+
|
|
266
|
+
return {
|
|
267
|
+
// 是否显示
|
|
268
|
+
currentModelValue,
|
|
269
|
+
// 当前宽度
|
|
270
|
+
currentWidth,
|
|
271
|
+
|
|
272
|
+
// 拖动事件
|
|
273
|
+
onTouchPan,
|
|
274
|
+
}
|
|
275
|
+
},
|
|
276
|
+
}
|
|
277
|
+
</script>
|
|
278
|
+
|
|
279
|
+
<style lang="scss" scoped>
|
|
280
|
+
.n-drawer {
|
|
281
|
+
// 拖拽手柄
|
|
282
|
+
&__drag-handle {
|
|
283
|
+
position: absolute;
|
|
284
|
+
top: 0;
|
|
285
|
+
bottom: 0;
|
|
286
|
+
width: 10px;
|
|
287
|
+
cursor: e-resize;
|
|
288
|
+
user-select: none;
|
|
289
|
+
z-index: 10;
|
|
290
|
+
right: 0;
|
|
291
|
+
|
|
292
|
+
// 左边侧滑菜单
|
|
293
|
+
&--left {
|
|
294
|
+
right: -5px;
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
// 右边侧滑菜单
|
|
298
|
+
&--right {
|
|
299
|
+
left: -5px;
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
</style>
|
|
@@ -267,18 +267,15 @@ export default {
|
|
|
267
267
|
|
|
268
268
|
const lists = []
|
|
269
269
|
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
})
|
|
280
|
-
}
|
|
281
|
-
}
|
|
270
|
+
const hasTreeAll = $n_isValidObject(treeAll.value)
|
|
271
|
+
|
|
272
|
+
for (const treeKey of treeTicked.value) {
|
|
273
|
+
lists.push({
|
|
274
|
+
id: treeKey,
|
|
275
|
+
label: hasTreeAll && $n_has(treeAll.value, treeKey) ?
|
|
276
|
+
treeAll.value[treeKey][props.showAllLevels ? 'path' : 'label']
|
|
277
|
+
: treeKey
|
|
278
|
+
})
|
|
282
279
|
}
|
|
283
280
|
|
|
284
281
|
return lists
|