You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
114 lines
3.6 KiB
114 lines
3.6 KiB
1 year ago
|
<template>
|
||
|
<!-- 自定义表单 -->
|
||
|
<div class="first">
|
||
|
<el-divider content-position="left">字段旧值</el-divider>
|
||
|
<BasicForm @register="registeroldFieldForm" />
|
||
|
<el-divider content-position="left">字段新值</el-divider>
|
||
|
<BasicForm @register="registernewFieldForm" />
|
||
|
<div v-if="datares">
|
||
|
<el-divider content-position="left">资料详情</el-divider>
|
||
|
<BasicTable @register="registerResourceTable">
|
||
|
<template #action="{ record }">
|
||
|
<TableAction :actions="getTableAction(record)" />
|
||
|
</template>
|
||
|
</BasicTable>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|
||
|
<script lang="ts" name="uploadfileApproval" setup>
|
||
|
import { onMounted, ref, reactive } from 'vue'
|
||
|
import { useForm, BasicForm } from '@/components/Form';
|
||
|
import { BasicTable, ActionItem, TableAction, useTable } from '@/components/Table';
|
||
|
import { formSchemas, resourcetableColumns } from '../../projectLib/projectInfo/projectInfo.data';
|
||
|
import { getFieldchangeByid, getFieldchangeFileinfoList } from '../../projectLib/projectInfo/projectInfo.api'
|
||
|
import { downloadFile } from "@/api/common/api"
|
||
|
let dataTo = defineProps(["fieldChangeid", "isEdit"])
|
||
|
console.log("dataTodataTodataTo", dataTo)
|
||
|
let datares = ref()
|
||
|
onMounted(async () => {
|
||
|
let res = await getFieldchangeByid({ fieldChangeid: dataTo.fieldChangeid })
|
||
|
datares.value = await getFieldchangeFileinfoList({ fieldChangeid: dataTo.fieldChangeid })
|
||
|
// if (datares.value) {
|
||
|
// setTableData(datares.value)
|
||
|
// }
|
||
|
formSchemas.forEach(item => {
|
||
|
if (item.field == res.fieldValue) {
|
||
|
resetoldSchema(item)
|
||
|
resetnewSchema(item)
|
||
|
let objnew = {}
|
||
|
objnew[res.fieldValue] = res.newvalue
|
||
|
setnewFieldsValue(objnew)
|
||
|
let objold = {}
|
||
|
objold[res.fieldValue] = res.oldvalue
|
||
|
setoldFieldsValue(objold)
|
||
|
setProps({ disabled: dataTo.isEdit == true ? false : true })
|
||
|
}
|
||
|
})
|
||
|
|
||
|
})
|
||
|
|
||
|
const [registeroldFieldForm, { setFieldsValue: setoldFieldsValue, resetSchema: resetoldSchema }] = useForm({
|
||
|
showActionButtonGroup: false,
|
||
|
labelCol: { style: { width: '120px' } },
|
||
|
wrapperCol: { style: { width: 'auto' } },
|
||
|
disabled: true
|
||
|
})
|
||
|
const [registernewFieldForm, { setProps, getFieldsValue: getnewFieldsValue, setFieldsValue: setnewFieldsValue, resetSchema: resetnewSchema, validate }] = useForm({
|
||
|
showActionButtonGroup: false,
|
||
|
labelCol: { style: { width: '120px' } },
|
||
|
wrapperCol: { style: { width: 'auto' } },
|
||
|
disabled: true
|
||
|
})
|
||
|
|
||
|
|
||
|
//项目资料table
|
||
|
const [registerResourceTable, { setTableData }] = useTable({
|
||
|
size: 'small',//紧凑型表格
|
||
|
title: '资料详情',
|
||
|
api: getFieldchangeFileinfoList,
|
||
|
columns: resourcetableColumns,
|
||
|
useSearchForm: false,
|
||
|
actionColumn: {
|
||
|
width: 140,
|
||
|
title: '操作',
|
||
|
dataIndex: 'action',
|
||
|
slots: { customRender: 'action' },
|
||
|
},
|
||
|
beforeFetch(param) {
|
||
|
param.fieldChangeid = dataTo.fieldChangeid
|
||
|
}
|
||
|
});
|
||
|
function getTableAction(record): ActionItem[] {
|
||
|
return [
|
||
|
{
|
||
|
label: '下载',
|
||
|
ifShow: true,
|
||
|
onClick: handleDetailpage.bind(null, record),
|
||
|
}
|
||
|
];
|
||
|
}
|
||
|
function handleDetailpage(record) {
|
||
|
console.log("我这一行的数据是", record)
|
||
|
let param = {
|
||
|
path: record.documentPath,
|
||
|
fileName: record.documentName
|
||
|
}
|
||
|
//
|
||
|
console.log("我这一行的数据是", param)
|
||
|
|
||
|
downloadFile("/huzhouUploadfileinfo/downloadfile", record.documentName, param)
|
||
|
}
|
||
|
const getCssVarName = (type: string) => {
|
||
|
return `--el-box-shadow${type ? '-' : ''}${type}`
|
||
|
}
|
||
|
defineExpose({ getnewFieldsValue, validate })
|
||
|
|
||
|
</script>
|
||
|
<style scoped>
|
||
|
|
||
|
.first {
|
||
|
padding-top: 20px;
|
||
|
margin-top: 20px;
|
||
|
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
|
||
|
}
|
||
|
</style>
|