<template>
|
<div>
|
<a-table :columns="columns" :data-source="dataSource" bordered :pagination="ipagination"
|
:scroll="{y:189}" :customRow="customRow" :size="size" rowKey="docId" @change="handleTableChange"/>
|
|
<DocumentModal ref="modalForm" @ok="modalFormOk"/>
|
</div>
|
</template>
|
|
<script>
|
import { getAction } from '@/api/manage'
|
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
|
import DocumentModal from '../../../../common/DocumentModal'
|
|
export default {
|
name: 'NcDocumentTableList',
|
components: { DocumentModal },
|
mixins: [JeecgListMixin],
|
props: {
|
currentTreeNodeInfo: {
|
type: Object
|
},
|
size: {
|
type: String
|
}
|
},
|
data() {
|
return {
|
disableMixinCreated: true,
|
columns: [
|
{
|
title: '序号',
|
dataIndex: 'rowIndex',
|
key: 'rowIndex',
|
width: 65,
|
align: 'center',
|
customRender: function(t, r, index) {
|
return parseInt(index) + 1
|
}
|
},
|
{ title: '文件名称', dataIndex: 'docName', align: 'center' },
|
{ title: '代码版本', dataIndex: 'docAlias', align: 'center' },
|
{ title: '出库状态', dataIndex: 'pullStatus_dictText', align: 'center' },
|
{ title: '状 态', dataIndex: 'docStatus_dictText', align: 'center' },
|
{ title: '系统指定版本', dataIndex: 'publishVersion', align: 'center' },
|
{ title: '上传时间', dataIndex: 'createTime', align: 'center' }
|
],
|
dataSource: [],
|
currentRightClickedDocumentInfo: {},
|
currentClickedDocumentInfo: {},
|
url: {
|
list: '/nc/doc/find/page'
|
}
|
}
|
},
|
created() {
|
this.$bus.$on('tableMenuItemMethodTrigger', this.triggerCorrespondingMethod)
|
},
|
methods: {
|
loadData(arg) {
|
if (!this.url.list) {
|
this.$message.error('请设置url.list属性!')
|
return
|
}
|
//加载数据 若传入参数1则加载第一页的内容
|
if (arg === 1) this.ipagination.current = 1
|
var params = this.getQueryParams()//查询条件
|
params.attributionId = this.currentTreeNodeInfo.id
|
params.attributionType = this.currentTreeNodeInfo.type
|
params.docClassCode = 'NC'
|
if (!params) return false
|
this.dataSource = []
|
this.loading = true
|
getAction(this.url.list + `/${this.ipagination.current}/${this.ipagination.pageSize}`, params).then((res) => {
|
if (res.success) {
|
this.dataSource = res.result.records
|
if (res.result.total) {
|
this.ipagination.total = res.result.total
|
} else {
|
this.ipagination.total = 0
|
}
|
} else {
|
this.$message.warning(res.message)
|
}
|
}).finally(() => {
|
this.loading = false
|
})
|
},
|
|
customRow(record) {
|
return {
|
on: {
|
contextmenu: event => {
|
event.preventDefault()
|
this.currentRightClickedDocumentInfo = Object.assign({ param: 'NC' }, record)
|
this.$emit('handleTableContextMenuOpen', this.currentRightClickedDocumentInfo)
|
},
|
click: () => {
|
if (this.currentClickedDocumentInfo.docId === record.docId) return
|
this.currentClickedDocumentInfo = Object.assign({}, record)
|
this.$bus.$emit('sendCurrentClickedDocumentInfo', record)
|
}
|
}
|
}
|
},
|
|
handleDocumentEdit(record, modalTitle) {
|
this.$refs.modalForm.edit(record)
|
this.$refs.modalForm.title = modalTitle
|
},
|
|
handleDocumentAssign(record, modalTitle) {
|
this.$refs.documentAssignModalRef.title = modalTitle
|
this.$refs.documentAssignModalRef.visible = true
|
},
|
|
triggerCorrespondingMethod({ methodName, level, modalTitle, tableRowInfo }) {
|
if (this[methodName]) this[methodName](tableRowInfo, modalTitle)
|
}
|
}
|
}
|
</script>
|
|
<style scoped>
|
|
</style>
|