田源
2024-03-22 95110fc987846d9ccfd330bed0b0aefefd395f0f
动态简易版分页
已修改2个文件
已添加1个文件
337 ■■■■■ 文件已修改
Source/ProjectWeb/src/components/dynamic-components/dynamic-TreeTable.vue 206 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/dynamic-table.vue 122 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/index.vue 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
Source/ProjectWeb/src/components/dynamic-components/dynamic-TreeTable.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,206 @@
<template>
  <div :id="'UI-dynamic-'+areasName+componentVO.oid" class="UI-dynamic">
    <avue-crud ref="treeTable"
               v-model="form"
               :data="TreeData"
               :option="option"
               :page.sync="pageType"
               @selection-change="TreeSelectChange">
      <template #icon="scope">
        <i :class="scope.row.icon"
           style="font-size:24px"></i>
      </template>
      <!--top区域按钮-->
      <template slot="menuLeft" slot-scope="scope">
        <dynamic-button :butttonList="componentVO.buttons" :selectList="selectList" LocationType="top"
                        type="table"></dynamic-button>
      </template>
      <!--menu区域按钮-->
      <template slot="menu" slot-scope="scope">
        <dynamic-button :butttonList="componentVO.buttons" :scope="scope" :selectList="selectList" LocationType="menu"
                        type="table"></dynamic-button>
      </template>
    </avue-crud>
  </div>
</template>
<script>
export default {
  name: "dynamic-TreeTable",
  props: {
    componentVO: {
      type: Object,
      default: {}
    },
    inDialog: {
      type: Boolean,
      default: false
    },
    areasName: {
      type: String,
      default: ''//westArea导航区
    },
    sourceData: {
      //菜单源数据或者弹窗时按钮所属区域的上一区域选中数据
      type: Object,
      default: {}
    },
    paramVOS: {
      type: Object,
      default: {}
    },
    isShow: {
      //所在区域是否已显示,针对tab和collapse
      type: Boolean,
      default: true
    },
    dataStore: {
      //弹窗时按钮所属区域选中数据
      type: Array,
      default: []
    },
    tableType: {
      type: String
    }
  },
  data() {
    return {
      parentHeight: '100%',//当前组件根节点元素高度
      page: {
        pageSize: 10,
        currentPage: 1,
        total: 50,
      },
      simplePage:{
        currentPage: 1,
        total: 100,
        pagerCount:4,
        layout:"prev, pager, next"
      },
      //表格树
      form: {},
      option: {
        height: '100%',
        addBtn: false,
        editBtn: false,
        delBtn: false,
        selection: true,
        tip:false,
        calcHeight: 15,
        indexFixed: false,
        menuFixed: false,
        column: [
          {
            label: '事件',
            prop: 'event',
            align: 'left',
            width: 200
          },
          {
            label: '时间线',
            prop: 'timeLine'
          },
          {
            label: '备注',
            prop: 'comment'
          }
        ],
        rowKey: 'id',
        rowParentKey: 'parentId',
      },
      TreeData: [
        {
          id: 10,
          event: '事件1',
          timeLine: 50,
          comment: '无'
        },
        {
          id: 1,
          event: '事件1',
          timeLine: 100,
          comment: '无',
          children: [
            {
              parentId: 1,
              id: 2,
              event: '事件2',
              timeLine: 10,
              comment: '无'
            },
            {
              parentId: 1,
              id: 3,
              event: '事件3',
              timeLine: 90,
              comment: '无',
              children: [
                {
                  parentId: 3,
                  id: 4,
                  event: '事件4',
                  timeLine: 5,
                  comment: '无'
                },
                {
                  parentId: 3,
                  id: 5,
                  event: '事件5',
                  timeLine: 10,
                  comment: '无'
                }
              ]
            }
          ]
        }
      ],
      TreeSelectList: []
    }
  },
  watch:{
    parentHeight:{
      handler(newval) {
        if(newval >50){
          this.option.height=newval;
          //doLayout不生效,手动设置表格高度
          this.$children[0].$children[1].$children[1].$children[0].$el.style.height=newval+'px';
          /*this.$nextTick(() => {
            if (this.$refs.dataTable && this.$refs.dataTable.doLayout) {
              this.$refs.dataTable.doLayout();
            }
          })*/
        }
      }
    },
    isShow:{
      handler(newval) {
        if(newval && this.$el.clientHeight>50) {
          this.parentHeight = this.$el.clientHeight - this.$children[0].$children[1].$children[0].$el.clientHeight - this.$children[0].$children[2].$el.clientHeight - 5;
        }
      }
    }
  },
  mounted() {
    if (this.$el.clientHeight > 50) {
      //父元素高度-按钮高度-分页高度
      this.parentHeight = this.$el.clientHeight - this.$children[0].$children[1].$children[0].$el.clientHeight - this.$children[0].$children[2].$el.clientHeight - 5;
    }
  },
  computed: {
    pageType() {
      return this.areasName === 'westArea' ? this.simplePage : this.page;
    }
  },
  methods: {
    TreeSelectChange(row) {
      this.TreeSelectList = row;
    }
  }
}
</script>
<style scoped>
</style>
Source/ProjectWeb/src/components/dynamic-components/dynamic-table.vue
@@ -1,11 +1,10 @@
<template>
  <div>
    <div class="UI-dynamic" :id="'UI-dynamic-'+areasName+componentVO.oid" v-if="tableType === 'table'">
    <div class="UI-dynamic" :id="'UI-dynamic-'+areasName+componentVO.oid">
      <avue-crud v-model="form"
                 ref="dataTable"
                 :data="tableList"
                 :option="option"
                 :page.sync="page"
                 :page.sync="pageType"
                 :table-loading="loading"
                 @selection-change="selectChange">
        <!--top区域按钮-->
@@ -19,30 +18,6 @@
        </template>
      </avue-crud>
    </div>
    <div class="UI-dynamic" :id="'UI-dynamic-'+areasName+componentVO.oid" v-if="tableType === 'TreeTable'">
      <avue-crud v-model="TreeForm"
                 :option="TreeOption"
                 :data="TreeData"
                 :page.sync="TreePage"
                 ref="treeTable"
                 @selection-change="TreeSelectChange">
        <template #icon="scope">
          <i :class="scope.row.icon"
             style="font-size:24px"></i>
        </template>
        <!--top区域按钮-->
        <template slot="menuLeft" slot-scope="scope">
          <dynamic-button LocationType="top" type="table":butttonList="componentVO.buttons" :selectList="selectList"></dynamic-button>
        </template>
        <!--menu区域按钮-->
        <template slot="menu" slot-scope="scope">
          <dynamic-button :scope="scope" LocationType="menu" type="table":butttonList="componentVO.buttons" :selectList="selectList"></dynamic-button>
        </template>
      </avue-crud>
    </div>
  </div>
</template>
<script>
@@ -92,12 +67,13 @@
      page: {
        pageSize: 10,
        currentPage: 1,
        total: 5,
        total: 50,
      },
      TreePage:{
        pageSize: 10,
      simplePage:{
        currentPage: 1,
        total: 5,
        total: 100,
        pagerCount:4,
        layout:"prev, pager, next"
      },
      //表格数据
      tableList: [
@@ -499,7 +475,8 @@
        addBtn: false,
        editBtn: false,
        delBtn: false,
        selection:true,
        selection: true,
        tip:false,
        height: '100%',
        calcHeight: 15,
        indexFixed: false,
@@ -507,84 +484,6 @@
        column: [],
      },
      selectList:[],
      //表格树
      TreeForm:{},
      TreeOption:{
        height: '100%',
        addBtn:false,
        editBtn:false,
        delBtn:false,
        selection: true,
        calcHeight: 15,
        indexFixed: false,
        menuFixed: false,
        column: [
          {
            label: '事件',
            prop: 'event',
            align: 'left',
            width: 200
          },
          {
            label: '时间线',
            prop: 'timeLine'
          },
          {
            label: '备注',
            prop: 'comment'
          }
        ],
        rowKey: 'id',
        rowParentKey: 'parentId',
      },
      TreeData:[
        {
          id: 10,
          event: '事件1',
          timeLine: 50,
          comment: '无'
        },
        {
          id: 1,
          event: '事件1',
          timeLine: 100,
          comment: '无',
          children: [
            {
              parentId: 1,
              id: 2,
              event: '事件2',
              timeLine: 10,
              comment: '无'
            },
            {
              parentId: 1,
              id: 3,
              event: '事件3',
              timeLine: 90,
              comment: '无',
              children: [
                {
                  parentId: 3,
                  id: 4,
                  event: '事件4',
                  timeLine: 5,
                  comment: '无'
                },
                {
                  parentId: 3,
                  id: 5,
                  event: '事件5',
                  timeLine: 10,
                  comment: '无'
                }
              ]
            }
          ]
        }
      ],
      TreeSelectList:[]
    }
  },
  computed: {
@@ -603,6 +502,9 @@
        };
      });
    },
    pageType() {
      return this.areasName === 'westArea' ? this.simplePage : this.page;
    }
  },
  watch:{
    parentHeight:{
Source/ProjectWeb/src/components/dynamic-components/index.vue
@@ -1,6 +1,5 @@
<template>
  <dynamic-table v-if="componentVO.uiComponentType=='table'"
                 tableType="table"
                 :key="areasName+'table-'+componentVO.oid"
                 :inDialog="inDialog"
                 :componentVO="componentVO"
@@ -10,8 +9,7 @@
                 :isShow="isShow">
  </dynamic-table>
  <dynamic-table v-else-if="componentVO.uiComponentType=='TreeTable'"
                 tableType="TreeTable"
  <dynamicTreeTable v-else-if="componentVO.uiComponentType=='TreeTable'"
                 :key="areasName+'table-'+componentVO.oid"
                 :inDialog="inDialog"
                 :componentVO="componentVO"
@@ -20,7 +18,7 @@
                 :paramVOS="paramVOS"
                 :isShow="isShow">
  </dynamic-table>
  </dynamicTreeTable>
  <dynamic-form v-else-if="componentVO.uiComponentType=='form'"
                :key="areasName+'form-'+componentVO.oid"
                :inDialog="inDialog"
@@ -56,9 +54,10 @@
import dynamicForm from "@/components/dynamic-components/dynamic-form"
import dynamicTree from "@/components/dynamic-components/dynamic-tree"
import dynamicCustom from "@/components/dynamic-components/dynamic-custom"
import dynamicTreeTable from "@/components/dynamic-components/dynamic-TreeTable"
export default {
  name: "dynamicIndex",
  components:{dynamicCustom, dynamicTree, dynamicForm, dynamicTable},
  components:{dynamicCustom, dynamicTree, dynamicForm, dynamicTable,dynamicTreeTable  },
  props:{
    componentVO:{
      type:Object,