fks-xuxinyue
4 months ago
8 changed files with 1005 additions and 413 deletions
@ -1,283 +1,97 @@ |
|||||
import { ref } from 'vue'; |
// 填报页表头
|
||||
import { http } from '/nerv-lib/util'; |
export const columns = [ |
||||
import { origanizemanage } from '/@/api/origanizemanage'; |
{ |
||||
import { carbonEmissionFactorLibrary } from '/@/api/carbonEmissionFactorLibrary'; |
title: '日期', |
||||
export const formConfig = (disabled) => { |
dataIndex: 'name', |
||||
return ref([ |
key: 'name', |
||||
{ |
width: 100, |
||||
field: 'fields', |
fixed: 'left', |
||||
component: 'NsChildForm', |
}, |
||||
componentProps: { |
{ |
||||
schemas: [ |
title: '消耗量', |
||||
{ |
children: [ |
||||
label: '排放源', |
{ |
||||
field: 'emissionSources', |
title: '数据来源', |
||||
component: 'NsInput', |
dataIndex: 'companyAddress', |
||||
componentProps: { |
key: 'companyAddress', |
||||
placeholder: '请输入排放源', |
width: 200, |
||||
maxLength: 20, |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请输入排放源', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
field: 'emissionType', |
|
||||
label: '排放分类', |
|
||||
component: 'NsCascader', |
|
||||
fieldMap: ['emissionType'], |
|
||||
componentProps: { |
|
||||
placeholder: '请选择排放分类', |
|
||||
api: carbonEmissionFactorLibrary.getCarbonFactorTree, |
|
||||
fieldNames: { label: 'emissionName', value: 'id' }, |
|
||||
showSearch: true, |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请选择排放分类', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
field: 'emissionGas', |
|
||||
label: '排放气体', |
|
||||
component: 'NsSelect', |
|
||||
componentProps: { |
|
||||
allowClear: true, |
|
||||
placeholder: '请选择排放气体', |
|
||||
options: [ |
|
||||
{ |
|
||||
label: 'CO2', |
|
||||
value: 'CO2', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'CO2e', |
|
||||
value: 'CO2e', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'SF6', |
|
||||
value:'SF6', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'CH4', |
|
||||
value: 'CH4', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'PFCs', |
|
||||
value: 'PFCs', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'HFCs', |
|
||||
value: 'HFCs', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请选择排放气体', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
// {
|
|
||||
// field: 'emissionProcess',
|
|
||||
// label: '排放环节',
|
|
||||
// component: 'NsSelectApi',
|
|
||||
// componentProps: {
|
|
||||
// api: carbonEmissionFactorLibrary.getEmissionProcess,
|
|
||||
// params: {
|
|
||||
// emissionType: sessionStorage.getItem('checkedTreeNode'),
|
|
||||
// },
|
|
||||
// resultField: 'data',
|
|
||||
// labelField: 'emissionProcess',
|
|
||||
// valueField: 'emissionProcess',
|
|
||||
// immediate: true,
|
|
||||
// autoSelectFirst: false,
|
|
||||
// filterOption:false,
|
|
||||
// showSearch:true,
|
|
||||
// autoClearSearchValue:false
|
|
||||
// },
|
|
||||
// },
|
|
||||
{ |
|
||||
label: '排放环节', |
|
||||
field: 'emissionProcess', |
|
||||
component: 'NsInput', |
|
||||
componentProps: { |
|
||||
placeholder: '请输入排放环节', |
|
||||
maxLength: 20, |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请输入排放环节', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
label: '排放因子', |
|
||||
field: 'emissionFactors', |
|
||||
component: 'NsInputNumber', |
|
||||
componentProps: { |
|
||||
placeholder: '请输入排放因子值', |
|
||||
maxLength: 20, |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请输入排放因子值', |
|
||||
trigger: 'change', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
field: 'carbonEmissionPrefix', |
|
||||
label: '碳排前缀', |
|
||||
component: 'NsSelect', |
|
||||
componentProps: { |
|
||||
disabled: true, |
|
||||
allowClear: true, |
|
||||
defaultValue: 't', |
|
||||
placeholder: '请选择碳排前缀', |
|
||||
options: [ |
|
||||
{ |
|
||||
label: 'g', |
|
||||
value: 'g', |
|
||||
}, |
|
||||
{ |
|
||||
label: 'kg', |
|
||||
value: 'kg', |
|
||||
}, |
|
||||
{ |
|
||||
label: 't', |
|
||||
value: 't', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请选择碳排前缀', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
label: '碳排后缀', |
|
||||
field: 'carbonEmissionSuffix', |
|
||||
component: 'NsInput', |
|
||||
componentProps: { |
|
||||
placeholder: '请输入碳排后缀', |
|
||||
maxLength: 20, |
|
||||
}, |
|
||||
rules: [ |
|
||||
{ |
|
||||
required: true, |
|
||||
message: '请输入碳排后缀', |
|
||||
}, |
|
||||
], |
|
||||
}, |
|
||||
{ |
|
||||
label: '已引用数', |
|
||||
field: 'numberOfReferences', |
|
||||
component: 'NsInput', |
|
||||
componentProps: { |
|
||||
defaultValue: 10, |
|
||||
disabled: true, |
|
||||
maxLength: 20, |
|
||||
}, |
|
||||
}, |
|
||||
{ |
|
||||
label: '参考文献', |
|
||||
field: 'reference', |
|
||||
component: 'NsTextarea', |
|
||||
componentProps: { |
|
||||
placeholder: '请输入参考文献', |
|
||||
maxLength: 20, |
|
||||
}, |
|
||||
}, |
|
||||
], |
|
||||
}, |
}, |
||||
}, |
{ |
||||
]); |
title: '数值', |
||||
}; |
dataIndex: 'companyName', |
||||
const options = ref([]); |
key: 'companyName', |
||||
|
}, |
||||
const getUserPerList = (transform, params = {}) => { |
], |
||||
return http.post(origanizemanage.queryUserPerList, { ...params }).then((res) => { |
}, |
||||
return res.data?.map((item) => { |
{ |
||||
item = { ...item, ...transform(item) }; |
title: '碳排因子', |
||||
return item; |
children: [ |
||||
}); |
{ |
||||
}); |
title: '数据来源', |
||||
}; |
dataIndex: 'companyAddress', |
||||
export const formConfig2 = (casData: any) => { |
key: 'companyAddress', |
||||
return ref([ |
width: 200, |
||||
{ |
}, |
||||
field: 'information', |
{ |
||||
component: 'NsCascader', |
title: '数值', |
||||
componentProps: { |
dataIndex: 'companyName', |
||||
placeholder: '请选择', |
key: 'companyName', |
||||
displayRender: ({ labels, selectedOptions }: any) => { |
|
||||
console.log(labels, selectedOptions); |
|
||||
|
|
||||
casData.value = selectedOptions.map(({ label, value }) => { |
|
||||
return { label, value }; |
|
||||
}); |
|
||||
return labels.join('/'); |
|
||||
}, |
|
||||
loadData: (selectedOptions, options) => { |
|
||||
console.log(selectedOptions, options, 'selectedOptions, options'); |
|
||||
|
|
||||
const targetOption = selectedOptions[selectedOptions.length - 1]; |
|
||||
let transForm, params; |
|
||||
// load options lazily
|
|
||||
if (!selectedOptions.length) { |
|
||||
transForm = (data) => { |
|
||||
data['label'] = data.orgName; |
|
||||
data['value'] = data.orgId; |
|
||||
data['isLeaf'] = false; |
|
||||
data['level'] = 1; |
|
||||
return data; |
|
||||
}; |
|
||||
getUserPerList(transForm).then((res) => { |
|
||||
options.value = [...res]; |
|
||||
}); |
|
||||
} |
|
||||
const id = targetOption?.value; |
|
||||
const level = targetOption?.level; |
|
||||
if (targetOption) { |
|
||||
targetOption.loading = true; |
|
||||
} |
|
||||
|
|
||||
if (level === 1) { |
|
||||
transForm = (data) => { |
|
||||
data['label'] = data.deptName; |
|
||||
data['value'] = data.deptId; |
|
||||
data['isLeaf'] = false; |
|
||||
data['level'] = 2; |
|
||||
return data; |
|
||||
}; |
|
||||
params = { orgId: id }; |
|
||||
} else if (level === 2) { |
|
||||
transForm = (data) => { |
|
||||
data['label'] = data.roleName; |
|
||||
data['value'] = data.roleId; |
|
||||
data['level'] = 3; |
|
||||
return data; |
|
||||
}; |
|
||||
params = { deptId: id }; |
|
||||
} |
|
||||
if (targetOption) { |
|
||||
getUserPerList(transForm, { ...params }).then((res) => { |
|
||||
targetOption.loading = false; |
|
||||
targetOption.children = [...res]; |
|
||||
}); |
|
||||
} |
|
||||
}, |
|
||||
}, |
}, |
||||
|
], |
||||
|
}, |
||||
|
{ |
||||
|
title: '排放量', |
||||
|
dataIndex: 'gender', |
||||
|
key: 'gender', |
||||
|
width: 80, |
||||
|
fixed: 'right', |
||||
|
}, |
||||
|
{ |
||||
|
title: '操作', |
||||
|
dataIndex: 'action', |
||||
|
key: 'action', |
||||
|
width: 80, |
||||
|
fixed: 'right', |
||||
|
}, |
||||
|
]; |
||||
|
// 凭证弹窗表头
|
||||
|
export const voucherColumns = [ |
||||
|
{ |
||||
|
title: '序号', |
||||
|
customRender: (text: any) => { |
||||
|
return text.index + 1; |
||||
}, |
}, |
||||
]); |
}, |
||||
}; |
{ |
||||
|
title: '日期', |
||||
|
dataIndex: 'age', |
||||
|
key: 'age', |
||||
|
}, |
||||
|
{ |
||||
|
title: '文件名称', |
||||
|
dataIndex: 'address', |
||||
|
key: 'address 1', |
||||
|
ellipsis: true, |
||||
|
}, |
||||
|
]; |
||||
|
// 编辑页中表头
|
||||
|
export const drawerColumns = [ |
||||
|
{ |
||||
|
title: '名称', |
||||
|
dataIndex: 'emissionSources', |
||||
|
}, |
||||
|
{ |
||||
|
title: '因子值', |
||||
|
dataIndex: 'emissionFactors', |
||||
|
}, |
||||
|
{ |
||||
|
title: '排放环节', |
||||
|
className: 'emissionProcess', |
||||
|
dataIndex: 'emissionProcess', |
||||
|
}, |
||||
|
{ |
||||
|
title: '数据来源', |
||||
|
className: 'dataSources', |
||||
|
dataIndex: 'dataSources', |
||||
|
}, |
||||
|
]; |
File diff suppressed because it is too large
Loading…
Reference in new issue