| | |
| | | <template> |
| | | <div> |
| | | <avue-crud v-model="form" |
| | | <div :id="'UI-dynamic-'+areasName+componentVO.oid" class="UI-dynamic"> |
| | | <avue-crud ref="dataTable" |
| | | v-model="form" |
| | | :data="tableList" |
| | | :option="option" |
| | | :page.sync="page" |
| | | :table-loading="loading"> |
| | | :page.sync="pageType" |
| | | :table-loading="loading" |
| | | @row-click="rowClickChange" |
| | | @search-change='searchChange' |
| | | @selection-change="selectChange"> |
| | | <!--top区域按钮--> |
| | | <template slot="menuLeft" slot-scope="scope"> |
| | | <dynamic-button LocationType="top" type="table":butttonList="butttonList" @buttonClick="buttonClick" ></dynamic-button> |
| | | <dynamic-button :butttonList="componentVO.buttons" :selectList="selectList" LocationType="top" |
| | | type="table"></dynamic-button> |
| | | </template> |
| | | |
| | | <!--menu区域按钮--> |
| | | <template slot="menu" slot-scope="scope"> |
| | | <dynamic-button :scope="scope" LocationType="menu" type="table":butttonList="butttonList" @buttonClick="buttonClick" ></dynamic-button> |
| | | <dynamic-button :butttonList="componentVO.buttons" :scope="scope" :selectList="selectList" LocationType="menu" |
| | | type="table"></dynamic-button> |
| | | </template> |
| | | </avue-crud> |
| | | <!-- 表格内按钮操作对话框表单 --> |
| | | <dynamic-form ref="dynamicForm" :formList="formList" :title="formName" :visible.sync="visible" |
| | | style="display: none"></dynamic-form> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import {validatenull} from '@/util/validate' |
| | | export default { |
| | | name: "dynamic-table", |
| | | props: { |
| | |
| | | paramVOS: { |
| | | type: Object, |
| | | default: {} |
| | | }, |
| | | isShow: { |
| | | //所在区域是否已显示,针对tab和collapse |
| | | type: Boolean, |
| | | default: true |
| | | }, |
| | | dataStore: { |
| | | //弹窗时按钮所属区域选中数据 |
| | | type: Array, |
| | | default: [] |
| | | }, |
| | | tableType: { |
| | | type: String |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | parentHeight: '100%',//当前组件根节点元素高度 |
| | | form: {}, |
| | | formName: '', |
| | | loading: false, |
| | | visible: false, |
| | | page: { |
| | | pageSize: 10, |
| | | currentPage: 1, |
| | | total: 5, |
| | | total: 50, |
| | | }, |
| | | //表格头 |
| | | tableHeadList: [ |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | field: "name", |
| | | fieldType: "text", |
| | | hidden: false, |
| | | title: "名称", |
| | | width: 100, |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | field: "code", |
| | | fieldType: "text", |
| | | hidden: false, |
| | | title: "编码", |
| | | width: 100 |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | comboxKey: "EnumReviewType", |
| | | field: "reviewtypetext", |
| | | fieldType: "combox", |
| | | hidden: false, |
| | | sortField: "reviewtype", |
| | | title: "类型", |
| | | width: 80 |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | field: "content", |
| | | fieldType: "textarea", |
| | | hidden: false, |
| | | title: "备注", |
| | | width: 150 |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | comboxKey: "ProcessReviewLC${lcstatus}", |
| | | field: "lcstatus_text", |
| | | fieldType: "text", |
| | | hidden: false, |
| | | sortField: "lcstatus", |
| | | title: "状态", |
| | | width: 100 |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | field: "creator_name", |
| | | fieldType: "text", |
| | | hidden: false, |
| | | sortField: "creator", |
| | | title: "创建人", |
| | | width: 80 |
| | | }, |
| | | { |
| | | align: "left", |
| | | colspan: 1, |
| | | dateFormate: "yyyy-MM-dd HH:mm:ss", |
| | | field: "createtime", |
| | | fieldType: "date", |
| | | hidden: false, |
| | | title: "创建日期", |
| | | width: 160 |
| | | } |
| | | ], |
| | | simplePage: { |
| | | currentPage: 1, |
| | | total: 100, |
| | | pagerCount: 4, |
| | | layout: "prev, pager, next" |
| | | }, |
| | | //表格数据 |
| | | tableList: [ |
| | | { |
| | |
| | | ts: "2022-02-18 14:35:53.177" |
| | | }, |
| | | ], |
| | | // 表单数据 |
| | | formList: [ |
| | | { |
| | | comboxKey: null, |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: null, |
| | | defaultValue: "", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "name", |
| | | hidden: false, |
| | | keyAttr: true, |
| | | prefix: null, |
| | | readOnly: false, |
| | | referConfig: null, |
| | | required: true, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: '$', |
| | | text: "名称", |
| | | tooltips: '名称', |
| | | type: "text", |
| | | unique: false, |
| | | verify: "" |
| | | }, |
| | | { |
| | | comboxKey: null, |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: null, |
| | | defaultValue: "", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "code", |
| | | hidden: false, |
| | | keyAttr: false, |
| | | prefix: null, |
| | | readOnly: false, |
| | | referConfig: null, |
| | | required: false, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: null, |
| | | disabled:true, |
| | | text: "编码", |
| | | tooltips: null, |
| | | type: "text", |
| | | unique: false, |
| | | verify: "" |
| | | }, |
| | | { |
| | | comboxKey: "EnumReviewType", |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: null, |
| | | defaultValue: "department", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "reviewtype", |
| | | hidden: false, |
| | | keyAttr: false, |
| | | prefix: null, |
| | | readOnly: false, |
| | | referConfig: null, |
| | | required: false, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: null, |
| | | text: "类型", |
| | | tooltips: null, |
| | | type: "combox", |
| | | unique: false, |
| | | verify: "", |
| | | dicData: [{ |
| | | label: '测试1', |
| | | value: 'department' |
| | | }, { |
| | | label: '测试2', |
| | | value: 'departments' |
| | | }] |
| | | }, |
| | | { |
| | | comboxKey: null, |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: null, |
| | | defaultValue: "", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "creator", |
| | | hidden: true, |
| | | keyAttr: false, |
| | | prefix: null, |
| | | readOnly: true, |
| | | referConfig: null, |
| | | required: false, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: null, |
| | | text: "创建人", |
| | | tooltips: null, |
| | | type: "text", |
| | | unique: false, |
| | | verify: "" |
| | | }, |
| | | { |
| | | comboxKey: null, |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: "yyyy-MM-dd HH:mm:ss", |
| | | defaultValue: "", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "createtime", |
| | | hidden: true, |
| | | keyAttr: false, |
| | | prefix: null, |
| | | readOnly: false, |
| | | referConfig: null, |
| | | required: false, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: null, |
| | | text: "创建时间", |
| | | tooltips: null, |
| | | type: "datetime", |
| | | unique: false, |
| | | verify: "" |
| | | }, |
| | | { |
| | | comboxKey: null, |
| | | customClass: null, |
| | | data: null, |
| | | dateFormate: null, |
| | | defaultValue: "", |
| | | displayExtension: "", |
| | | extendAttrMap: null, |
| | | extendAttrString: null, |
| | | field: "content", |
| | | hidden: false, |
| | | keyAttr: false, |
| | | prefix: null, |
| | | readOnly: false, |
| | | referConfig: null, |
| | | required: false, |
| | | selectLibFlag: null, |
| | | showField: null, |
| | | suffix: null, |
| | | text: "备注", |
| | | tooltips: null, |
| | | type: "textarea", |
| | | unique: false, |
| | | verify: "" |
| | | }, |
| | | ], |
| | | // 按钮数据 |
| | | butttonList: [ |
| | | { |
| | | actionVO: { |
| | | actionCls: "", |
| | | actionUsedType: "business", |
| | | bsUrl: "null", |
| | | createTime: "2013-11-01 15:17:45.000", |
| | | creator: "eddieliu", |
| | | csClass: "plm.uif.actions.client.AddAction", |
| | | description: "创建业务对象", |
| | | id: "add", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2013-11-01 15:17:45.000", |
| | | licensors: null, |
| | | name: "创建", |
| | | oid: "65274704-5557-231C-E3EA-0B32B9BD5A0B" |
| | | }, |
| | | areaType: "tab", |
| | | authorization: true, |
| | | children: null, |
| | | createTime: "2022-07-18 17:29:10.000", |
| | | creator: "developer", |
| | | csUrl: "plm.uif.actions.client.AddAction", |
| | | description: "", |
| | | displayMode: "textandimage", |
| | | hidden: false, |
| | | iconPath: "", |
| | | id: "add", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2022-07-18 17:29:10.000", |
| | | name: "新增", |
| | | oid: "DD34108A-5978-334C-7A2A-45F2EE158B1D", |
| | | orderNum: 1, |
| | | paramVOS: { |
| | | form: "DepartmentProcessReviewForm", |
| | | context: "EditDepartmentProcessReview", |
| | | type: "processreview", |
| | | initvalue: "reviewtype=department", |
| | | location: 'top', |
| | | buttonType: 'primary', |
| | | buttonMethods: 'add' |
| | | }, |
| | | pkComponent: "D99AD59E-563F-AB7A-F307-794B929114CD", |
| | | pkParentOid: "", |
| | | url: "null" |
| | | }, |
| | | { |
| | | actionVO: { |
| | | actionCls: "", |
| | | actionUsedType: "business", |
| | | bsUrl: "BaseEditAction#doAction", |
| | | createTime: "2013-11-09 10:32:41.000", |
| | | creator: "eddieliu", |
| | | csClass: "plm.uif.actions.client.EditAction", |
| | | description: "修改业务对象", |
| | | id: "edit", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2013-11-09 10:32:41.000", |
| | | licensors: null, |
| | | name: "修改", |
| | | oid: "F8534EFE-130B-0CB3-D477-2AC7B19B7DC4" |
| | | }, |
| | | areaType: "tab", |
| | | authorization: true, |
| | | children: null, |
| | | createTime: "2022-07-18 17:29:10.000", |
| | | creator: "developer", |
| | | csUrl: "plm.uif.actions.client.EditAction", |
| | | description: "", |
| | | displayMode: "textandimage", |
| | | hidden: false, |
| | | iconPath: "", |
| | | id: "edit", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2022-07-18 17:29:10.000", |
| | | name: "修改", |
| | | oid: "F50F37CE-26FF-8BC1-F87A-FFD9CFA8CE57", |
| | | orderNum: 2, |
| | | paramVOS: { |
| | | form: "DepartmentProcessReviewForm", |
| | | checkNotOperation: "${lcstatus}=Auditing&${lcstatus}=Waiting", |
| | | location: 'menu', |
| | | buttonType: 'text', |
| | | icon: "el-icon-edit", |
| | | buttonMethods: 'edit' |
| | | }, |
| | | pkComponent: "D99AD59E-563F-AB7A-F307-794B929114CD", |
| | | pkParentOid: "", |
| | | url: "BaseEditAction#doAction" |
| | | }, |
| | | { |
| | | actionVO: { |
| | | actionCls: "", |
| | | actionUsedType: "business", |
| | | bsUrl: "BaseDeleteAction", |
| | | createTime: "2013-11-09 10:33:08.000", |
| | | creator: "1", |
| | | csClass: "plm.uif.actions.client.DeleteAction", |
| | | description: "删除业务对象", |
| | | id: "del", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2013-11-09 10:33:08.000", |
| | | licensors: null, |
| | | name: "删除", |
| | | oid: "2655E9F0-014B-DFEC-6F92-A6D1C51FDA19" |
| | | }, |
| | | areaType: "tab", |
| | | authorization: true, |
| | | children: null, |
| | | createTime: "2022-07-18 17:29:10.000", |
| | | creator: "developer", |
| | | csUrl: "plm.uif.actions.client.DeleteAction", |
| | | description: "", |
| | | displayMode: "textandimage", |
| | | hidden: false, |
| | | iconPath: "", |
| | | id: "del", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2022-07-18 17:29:10.000", |
| | | name: "删除", |
| | | oid: "A8914C35-721B-A1E3-1EEE-3A9196DF5EC9", |
| | | orderNum: 3, |
| | | paramVOS: { |
| | | owner: "true", |
| | | checkNotOperation: "${lcstatus}=Auditing&${lcstatus}=Waiting", |
| | | state: "Editing", |
| | | location: 'menu', |
| | | buttonType: 'text', |
| | | icon: "el-icon-delete", |
| | | buttonMethods: 'delete' |
| | | }, |
| | | pkComponent: "D99AD59E-563F-AB7A-F307-794B929114CD", |
| | | pkParentOid: "", |
| | | url: "BaseDeleteAction" |
| | | }, |
| | | { |
| | | actionVO: { |
| | | actionCls: "", |
| | | actionUsedType: "business", |
| | | bsUrl: "BaseStartWorkflowAction#doAction", |
| | | createTime: "2014-03-17 10:14:40.000", |
| | | creator: "developer", |
| | | csClass: "plm.uif.actions.client.LaunchWorkFlowAction", |
| | | description: "启动流程", |
| | | id: "launchworkflow", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2014-03-17 10:14:40.000", |
| | | licensors: null, |
| | | name: "启动流程", |
| | | oid: "56FE9470-AA2B-403B-F029-0A120FC94536" |
| | | }, |
| | | areaType: "tab", |
| | | authorization: true, |
| | | children: null, |
| | | createTime: "2022-07-18 17:29:10.000", |
| | | creator: "developer", |
| | | csUrl: "plm.uif.actions.client.LaunchWorkFlowAction", |
| | | description: "", |
| | | displayMode: "textandimage", |
| | | hidden: false, |
| | | iconPath: "", |
| | | id: "launchworkflow", |
| | | lastModifier: "developer", |
| | | lastModifyTime: "2022-07-18 17:29:10.000", |
| | | name: "审签", |
| | | oid: "9963FA86-F146-FBD3-2AC2-51A7AAAAB825", |
| | | orderNum: 4, |
| | | paramVOS: { |
| | | owner: "true", |
| | | autoSubmitFirst: "false", |
| | | flowtemplates: "工艺评审审签流程", |
| | | state: "Editing", |
| | | type: "processreview", |
| | | location: 'top', |
| | | buttonMethods: 'form' |
| | | }, |
| | | pkComponent: "D99AD59E-563F-AB7A-F307-794B929114CD", |
| | | pkParentOid: "", |
| | | url: "BaseStartWorkflowAction#doAction" |
| | | }, |
| | | ] |
| | | } |
| | | }, |
| | | computed: { |
| | | option() { |
| | | return { |
| | | option: { |
| | | index: true, |
| | | addBtn: false, |
| | | editBtn: false, |
| | | delBtn: false, |
| | | height: 'auto', |
| | | selection: true, |
| | | tip: false, |
| | | height: '100%', |
| | | calcHeight: 15, |
| | | indexFixed: false, |
| | | menuFixed: false, |
| | | column: this.updatedColumns, |
| | | }; |
| | | }, |
| | | searchMenuSpan:12, |
| | | searchShow:false, |
| | | column: [], |
| | | }, |
| | | selectList: [], |
| | | } |
| | | }, |
| | | computed: { |
| | | updatedColumns() { |
| | | return this.tableHeadList.map(item => { |
| | | const queryFields = !validatenull(this.componentVO.tableDefineVO.queryColumns) ? this.componentVO.tableDefineVO.queryColumns.map(item => item.field) : []; |
| | | |
| | | return this.componentVO.tableDefineVO.cols[0].map(item => { |
| | | const typeValue = item.fieldType === 'text' || item.fieldType === 'combox' ? 'input' : item.fieldType; // 表单Type类型 |
| | | const search = queryFields.includes(item.field); // 判断 field 是否在 queryColumns 里 |
| | | |
| | | return { |
| | | align: item.align, |
| | |
| | | hidden: item.hidden, |
| | | label: item.title, |
| | | width: item.width, |
| | | search: search |
| | | }; |
| | | }); |
| | | }, |
| | | pageType() { |
| | | return this.areasName === 'westArea' ? this.simplePage : this.page; |
| | | } |
| | | }, |
| | | 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; |
| | | } |
| | | } |
| | | } |
| | | }, |
| | | created() { |
| | | this.option.column = this.updatedColumns; |
| | | }, |
| | | 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; |
| | | } |
| | | }, |
| | | methods: { |
| | | buttonClick(scope, item) { |
| | | this.formName = item.name; |
| | | |
| | | function handleAdd() { |
| | | this.visible = true; |
| | | } |
| | | |
| | | function handleEdit() { |
| | | this.visible = true; |
| | | this.$refs.dynamicForm.form = scope.row; |
| | | } |
| | | |
| | | function handleDelete() { |
| | | this.$message.success('删除成功!'); |
| | | } |
| | | |
| | | const methodHandlers = { |
| | | add: handleAdd.bind(this), |
| | | edit: handleEdit.bind(this), |
| | | delete: handleDelete.bind(this), |
| | | }; |
| | | |
| | | const method = item.paramVOS.buttonMethods; |
| | | const handler = methodHandlers[method]; |
| | | if (handler) { |
| | | handler(); |
| | | } else { |
| | | this.$message.error('请重新配置按钮!') |
| | | } |
| | | rowClickChange(row){ |
| | | this.$refs.dataTable.toggleRowSelection(row); |
| | | }, |
| | | selectChange(row) { |
| | | this.selectList = row; |
| | | }, |
| | | searchChange(form,done){ |
| | | console.log(form) |
| | | done() |
| | | this.$emit("setDataStore", { |
| | | area: this.areasName, |
| | | dataStore:row |
| | | }); |
| | | } |
| | | } |
| | | } |