ny
昨天 282fbc6488f4e8ceb5fda759f963ee88fbf7b999
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
<script lang="ts">
import type { PropType } from 'vue';
 
import type { ColumnChangeParam, TableSetting } from '../../types/table';
 
import { computed, defineComponent, unref } from 'vue';
 
import { useTableContext } from '../../hooks/useTableContext';
import ColumnSetting from './ColumnSetting.vue';
import ExpandSetting from './ExpandSetting.vue';
import FullScreenSetting from './FullScreenSetting.vue';
import RedoSetting from './RedoSetting.vue';
import SizeSetting from './SizeSetting.vue';
 
export default defineComponent({
  components: {
    ColumnSetting,
    ExpandSetting,
    FullScreenSetting,
    RedoSetting,
    SizeSetting,
  },
  emits: ['columnsChange'],
  name: 'TableSetting',
  props: {
    setting: {
      default: () => ({}),
      type: Object as PropType<TableSetting>,
    },
  },
  setup(props, { emit }) {
    const table = useTableContext();
 
    const getSetting = computed((): TableSetting => {
      return {
        expand: true,
        fullScreen: false,
        redo: true,
        setting: true,
        size: false,
        ...props.setting,
      };
    });
    const getIsTreeTable = computed(() => {
      const getBindValues = table.getBindValues;
      return unref(getBindValues).isTreeTable;
    });
 
    function handleColumnChange(data: ColumnChangeParam[]) {
      emit('columnsChange', data);
    }
 
    function getTableContainer() {
      return table ? unref(table.wrapRef) : document.body;
    }
 
    return { getIsTreeTable, getSetting, getTableContainer, handleColumnChange };
  },
});
</script>
<template>
  <div class="table-settings">
    <ExpandSetting v-if="getIsTreeTable && getSetting.expand" />
    <RedoSetting v-if="getSetting.redo" />
    <SizeSetting v-if="getSetting.size" />
    <ColumnSetting v-if="getSetting.setting" @columns-change="handleColumnChange" />
    <FullScreenSetting v-if="getSetting.fullScreen" />
  </div>
</template>
<style lang="scss">
.table-settings {
  display: flex;
  align-items: center;
 
  & > * {
    margin-left: 10px;
  }
 
  svg {
    width: 1.3em;
    height: 1.3em;
  }
}
</style>