103 lines
2.5 KiB
Vue
Raw Normal View History

2023-04-03 00:05:09 +08:00
<template>
<div class="top-right-btn" :style="style">
<el-row>
<el-tooltip v-if="search" class="item" effect="dark" :content="showSearch ? '隐藏搜索' : '显示搜索'" placement="top">
2023-04-03 00:05:09 +08:00
<el-button circle icon="Search" @click="toggleSearch()" />
</el-tooltip>
<el-tooltip class="item" effect="dark" content="刷新" placement="top">
<el-button circle icon="Refresh" @click="refresh()" />
</el-tooltip>
<el-tooltip v-if="columns" class="item" effect="dark" content="显示/隐藏列" placement="top">
<div class="show-btn">
<el-popover placement="bottom" trigger="click">
<div class="tree-header">显示/隐藏列</div>
<el-tree
ref="columnRef"
:data="columns"
show-checkbox
node-key="key"
:props="{ label: 'label', children: 'children' } as any"
@check="columnChange"
></el-tree>
<template #reference>
<el-button circle icon="Menu" />
</template>
</el-popover>
</div>
2023-04-03 00:05:09 +08:00
</el-tooltip>
</el-row>
</div>
</template>
2023-04-02 01:01:56 +08:00
<script setup lang="ts">
import { propTypes } from '@/utils/propTypes';
2023-03-15 15:59:21 +08:00
const props = defineProps({
showSearch: propTypes.bool.def(true),
columns: propTypes.fieldOption,
search: propTypes.bool.def(true),
gutter: propTypes.number.def(10)
});
2023-03-15 15:59:21 +08:00
const columnRef = ref<ElTreeInstance>();
2023-03-15 15:59:21 +08:00
const emits = defineEmits(['update:showSearch', 'queryTable']);
const style = computed(() => {
const ret: any = {};
if (props.gutter) {
ret.marginRight = `${props.gutter / 2}px`;
}
return ret;
2023-03-15 15:59:21 +08:00
});
// 搜索
function toggleSearch() {
emits('update:showSearch', !props.showSearch);
2023-03-15 15:59:21 +08:00
}
// 刷新
function refresh() {
emits('queryTable');
2023-03-15 15:59:21 +08:00
}
// 更改数据列的显示和隐藏
function columnChange(...args: any[]) {
props.columns?.forEach((item) => {
item.visible = args[1].checkedKeys.includes(item.key);
});
2023-03-15 15:59:21 +08:00
}
// 显隐列初始默认隐藏列
2023-04-02 01:01:56 +08:00
onMounted(() => {
props.columns?.forEach((item) => {
if (item.visible) {
columnRef.value?.setChecked(item.key, true, false);
// value.value.push(item.key);
}
});
});
2023-03-15 15:59:21 +08:00
</script>
2023-04-02 01:01:56 +08:00
<style lang="scss" scoped>
2023-03-15 15:59:21 +08:00
:deep(.el-transfer__button) {
border-radius: 50%;
display: block;
margin-left: 0px;
}
:deep(.el-transfer__button:first-child) {
margin-bottom: 10px;
}
.my-el-transfer {
text-align: center;
}
.tree-header {
width: 100%;
line-height: 24px;
text-align: center;
}
.show-btn {
margin-left: 12px;
}
2023-04-02 01:01:56 +08:00
</style>