|
@@ -35,6 +35,21 @@ export default defineComponent({
|
|
return props.clearable && !props.disabled && !isEmpty.value
|
|
return props.clearable && !props.disabled && !isEmpty.value
|
|
})
|
|
})
|
|
|
|
|
|
|
|
+ // 多选显示的标签
|
|
|
|
+ const currentValues = computed(() => {
|
|
|
|
+ if (selectLabel.value == null) {
|
|
|
|
+ return selectLabel.value ?? []
|
|
|
|
+ }
|
|
|
|
+ return selectLabel.value.slice(0, props.maxTagCount)
|
|
|
|
+ })
|
|
|
|
+ // 多选折叠的标签
|
|
|
|
+ const omittedValues = computed(() => {
|
|
|
|
+ if (selectLabel.value == null) {
|
|
|
|
+ return []
|
|
|
|
+ }
|
|
|
|
+ return selectLabel.value.slice(props.maxTagCount)
|
|
|
|
+ })
|
|
|
|
+
|
|
onMounted(() => {
|
|
onMounted(() => {
|
|
if (props.initValue) {
|
|
if (props.initValue) {
|
|
initValueChange(props.initValue)
|
|
initValueChange(props.initValue)
|
|
@@ -115,6 +130,7 @@ export default defineComponent({
|
|
} else {
|
|
} else {
|
|
selectLabel.value = value[props.labelKey] as any
|
|
selectLabel.value = value[props.labelKey] as any
|
|
}
|
|
}
|
|
|
|
+ updateModelValue(props.multiple ? value.map((x: any) => x[props.valueKey]) : value[props.valueKey])
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -186,6 +202,8 @@ export default defineComponent({
|
|
visible,
|
|
visible,
|
|
isEmpty,
|
|
isEmpty,
|
|
loading,
|
|
loading,
|
|
|
|
+ currentValues,
|
|
|
|
+ omittedValues,
|
|
tableData,
|
|
tableData,
|
|
closeEnable,
|
|
closeEnable,
|
|
onFocus,
|
|
onFocus,
|
|
@@ -213,7 +231,7 @@ export default defineComponent({
|
|
teleported
|
|
teleported
|
|
>
|
|
>
|
|
<template #reference>
|
|
<template #reference>
|
|
- <div class="table-select-container">
|
|
|
|
|
|
+ <div class="table-select-container" :class="{ 'table-multiple-select': multiple }">
|
|
<el-input
|
|
<el-input
|
|
:size="size"
|
|
:size="size"
|
|
:disabled="disabled"
|
|
:disabled="disabled"
|
|
@@ -245,17 +263,20 @@ export default defineComponent({
|
|
</el-input>
|
|
</el-input>
|
|
<div class="table-select-multiple" v-if="multiple">
|
|
<div class="table-select-multiple" v-if="multiple">
|
|
<el-tag
|
|
<el-tag
|
|
- type="info"
|
|
|
|
|
|
+ :type="tagType"
|
|
size="small"
|
|
size="small"
|
|
disable-transitions
|
|
disable-transitions
|
|
closable
|
|
closable
|
|
style="margin-right: 5px"
|
|
style="margin-right: 5px"
|
|
- v-for="item in selectLabel"
|
|
|
|
|
|
+ v-for="item in currentValues"
|
|
:key="item[valueKey]"
|
|
:key="item[valueKey]"
|
|
@close="onItemClear(item)"
|
|
@close="onItemClear(item)"
|
|
>
|
|
>
|
|
{{ item[labelKey] }}
|
|
{{ item[labelKey] }}
|
|
</el-tag>
|
|
</el-tag>
|
|
|
|
+ <el-tag v-if="omittedValues && omittedValues.length" size="small" disable-transitions :type="tagType">
|
|
|
|
+ + {{ omittedValues.length }} ...
|
|
|
|
+ </el-tag>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
@@ -324,13 +345,23 @@ export default defineComponent({
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
+.table-multiple-select {
|
|
|
|
+ :deep(.el-input) {
|
|
|
|
+ position: absolute;
|
|
|
|
+ width: 100%;
|
|
|
|
+ height: 100%;
|
|
|
|
+ top: 0;
|
|
|
|
+ left: 0;
|
|
|
|
+ }
|
|
|
|
+}
|
|
.table-select-multiple {
|
|
.table-select-multiple {
|
|
- position: absolute;
|
|
|
|
|
|
+ position: relative;
|
|
top: 0px;
|
|
top: 0px;
|
|
width: calc(100% - 24px);
|
|
width: calc(100% - 24px);
|
|
height: 100%;
|
|
height: 100%;
|
|
|
|
+ min-height: 30px;
|
|
z-index: 2;
|
|
z-index: 2;
|
|
- padding: 4px 10px;
|
|
|
|
|
|
+ padding: 2px 10px 4px 10px;
|
|
box-sizing: border-box;
|
|
box-sizing: border-box;
|
|
}
|
|
}
|
|
.table-select-pagination {
|
|
.table-select-pagination {
|