<template> <div> <!-- <a-table :columns="tableColumns" :data-source="data" bordered :pagination="false" :scroll="{ x: 2000 }"> <template #bodyCell="{ column, text, record }"> <template v-if="column.key === 'action'"> <span> <a @click="editData(record)">编辑</a> <a-divider type="vertical" /> <a @click="delData(record)">删除</a> </span> </template> </template> <template #title> <a-date-picker v-model:value="selectYear" picker="year" @change="changeYearData" valueFormat="YYYY" /> <div class="buttonGroup"> <a-button type="primary" @click="addNewData">新增</a-button> <a-button type="primary">导入</a-button> <a-button type="primary">导出</a-button> <a-button type="primary">模板下载</a-button> <a-button type="primary" @click="uploadVoucher">上传凭证</a-button> <a-button type="primary">凭证下载</a-button> </div> </template> </a-table> --> <ns-view-list-table v-bind="tableConfig" :model="data" ref="mainRef" :scroll="{ x: 1500}" /> <!-- <a-pagination :current="queryParams.pageNum" :total="total" :page-size="queryParams.pageSize" style="display: flex;justify-content: center;margin-top: 16px;" :show-size-changer="true" :show-quick-jumper="true" @change="onChange" /> --> <!-- 新增数据库数据 --> <a-drawer :width="500" :visible="visible" :body-style="{ paddingBottom: '80px' }" :footer-style="{ textAlign: 'right' }" destroyOnClose @close="onClose"> <a-form ref="formRef" :model="formState" :rules="rules" :label-col="labelCol" :wrapper-col="wrapperCol" > <a-form-item ref="name" label="能源种类" name="energyType"> <a-input v-model:value="formState.energyType" placeholder="请输入能源种类" /> </a-form-item> <a-form-item label="计量单位" name="unit"> <a-cascader v-model:value="formState.unit" :options="measurementUnit" /> </a-form-item> <a-form-item label="自动采集节点" name="collectionNode"> <a-tree-select v-model:value="formState.collectionNode" :tree-line="true" :tree-data="treeData" > </a-tree-select> </a-form-item> <a-form-item label="计算碳排" name="isComputeCarbon"> <a-radio-group v-model:value="formState.isComputeCarbon" @change="changeRadio"> <a-radio :value="0">是</a-radio> <a-radio :value="1">否</a-radio> </a-radio-group> </a-form-item> <a-form-item label="排放类型" name="emissionType" :required="isRequired"> <a-select v-model:value="formState.emissionType" placeholder="请选择排放类型"> <a-select-option v-for="(item, index) in emissionTypeDic" :key="index" :value="item.id"> {{ item.cnValue }} </a-select-option> </a-select> </a-form-item> <a-row> <a-col :span="24" style="display:flex;justify-content: space-around;"> <a-form-item label="1月" name="janFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.janFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="2月" name="febFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.febFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="3月" name="marFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.marFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> </a-col> <a-col :span="24" style="display:flex;justify-content: space-around;"> <a-form-item label="4月" name="aprFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.aprFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="5月" name="mayFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.mayFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="6月" name="junFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.junFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> </a-col> <a-col :span="24" style="display:flex;justify-content: space-around;"> <a-form-item label="7月" name="julFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.julFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="8月" name="augFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.augFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="9月" name="sepFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.sepFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> </a-col> <a-col :span="24" style="display:flex;justify-content: space-around;"> <a-form-item label="10月" name="octFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.octFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="11月" name="novFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.novFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> <a-form-item label="12月" name="decFlag" :label-col="switchLabelCol" :wrapper-col="switchWrapperCol"> <a-switch v-model:checked="formState.decFlag" :checked-value="1" :unCheckedValue="0" /> </a-form-item> </a-col> </a-row> </a-form> <template #footer> <a-button style="margin-right: 8px" @click="onClose">取消</a-button> <a-button type="primary" @click="onSubmit">确定</a-button> </template> </a-drawer> <!-- 上传凭证弹窗 --> <a-modal :visible="openUpload" title="凭证上传" @ok="handleOk" @cancel="closeOpenUpload"> <a-upload-dragger v-model:fileList="fileList" name="file" :multiple="true" action="https://www.mocky.io/v2/5cc8019d300000980a055e76" @change="handleChange" @drop="handleDrop" > <p class="ant-upload-drag-icon"> <inbox-outlined></inbox-outlined> </p> <p class="ant-upload-hint" style="display: flex;flex-direction: column;"> <p>1.仅支持pdf格式文件或文件夹</p> <p>2.文件命名规则为【能源种类_年份】</p> <p>3.每次上传自动覆盖</p> </p> </a-upload-dragger> </a-modal> </div> </template> <script lang="ts" setup> import { ref,reactive, toRaw } from 'vue'; import type { UnwrapRef } from 'vue'; import type { Rule } from 'ant-design-vue/es/form'; import { Pagination,message,Modal } from 'ant-design-vue'; import { InboxOutlined } from '@ant-design/icons-vue'; import type { CascaderProps,TreeSelectProps,UploadChangeParam } from 'ant-design-vue'; import { NsMessage } from '/nerv-lib/component'; import dayjs, { Dayjs } from 'dayjs'; import { http } from '/nerv-lib/util/http'; import { tableColumns } from '../config'; import { energyConsumption,carbonEmissionFactorLibrary } from '/@/api/carbonEmissionFactorLibrary'; import { group } from '/@/api/deviceManage'; import { dict } from '/@/api'; defineOptions({ energyType: 'EnergyConsumption', // 与页面路由name一致缓存才可生效 components: { 'a-pagination': Pagination, }, }); const orgId = ref(''); const result = JSON.parse(sessionStorage.getItem('ORGID')!); orgId.value = result; const fetch = (api, params = { orgId } ) => { return http.post(api, params); }; const selectYear = ref<Dayjs>(dayjs( new Date().getFullYear().toString())); const total = ref<number>() const queryParams = ref({ pageNum: 1, pageSize: 10, orgId: orgId.value, year: selectYear.value.format('YYYY') }) const isRequired = ref(false); const visible = ref(false); const openUpload = ref<boolean>(false); const data = ref([]); interface FormState { energyType: string; unit: string; collectionNode: string; emissionType: string | undefined; isComputeCarbon: string; janFlag: string; febFlag: string; marFlag: string; aprFlag: string; mayFlag: string; junFlag: string; julFlag: string; augFlag: string; sepFlag: string; octFlag: string; novFlag: string; decFlag: string; } const formRef = ref(); const labelCol = { span: 5 }; const wrapperCol = { span: 19 }; const switchLabelCol = { span: 10 }; const switchWrapperCol = { span: 14 }; const formState = ref({}) // 定义form表单的必填 const rules: Record<string, Rule[]> = { energyType: [{ required: true, message: '请输入能源种类', trigger: 'change' }], isComputeCarbon: [{ required: true, message: '请选择是否计算碳排', trigger: 'change' }] }; // 排放类型的变量 const emissionTypeDic = ref() // 计量单位的变量 const measurementUnit = ref([]) // 定义自动采集节点数的变量 const treeData = ref<TreeSelectProps['treeData']>([]); // 年份选择改变触发 const changeYearData = () => { queryParams.value.year = selectYear.value getTableList() } const mainRef = ref(); const year = selectYear.value.format('YYYY') const tableConfig = ref({ title: '能耗统计', api: energyConsumption.pageList, params: queryParams.value, headerActions: [ { label: '新增', name: 'userAdd', type: 'primary', handle: () => { getDictList() visible.value = true }, }, { label: '导入', type: 'primary', name: 'userImport', handle: () => {}, }, { label: '导出', type: 'primary', name: 'userExports', }, { label: '模板下载', type: 'primary', name: 'userExports', }, { label: '上传凭证', type: 'primary', handle: () => { openUpload.value = true; }, }, { label: '凭证下载', type: 'primary', name: 'userExports', }, ], columns: [ { title: '序号', customRender: (text: any) => { return text.index + 1; }, }, { title: '能源种类', dataIndex: 'energyType', }, { title: '计量单位', className: 'unit', dataIndex: 'unit', }, { title: '全年', dataIndex: 'yearly', }, { title: '1月', dataIndex: 'jan', // customRender: ({ text, record }) => ({ // children: text, // attrs: { // style: record.janFlag === 1 ? 'color: red' : 'color: blue' // } // }) }, { title: '2月', dataIndex: 'feb', }, { title: '3月', dataIndex: 'mar', }, { title: '4月', dataIndex: 'apr', }, { title: '5月', dataIndex: 'may', }, { title: '6月', dataIndex: 'jun', }, { title: '7月', dataIndex: 'jul', }, { title: '8月', dataIndex: 'aug', }, { title: '9月', dataIndex: 'sep', }, { title: '10月', dataIndex: 'oct', }, { title: '11月', dataIndex: 'nov', }, { title: '12月', dataIndex: 'dec', }, ], columnActions: { title: '操作', actions: [ { label: '编辑', name: 'userEdit', handle: (record: any) => { getDictList() visible.value = true fetch(energyConsumption.findById , {id : record.id }).then((res) => { if(res.data.unit){ res.data.unit = res.data.unit.split(',') } formState.value = res.data }); }, }, { label: '删除', name: 'userDelete', dynamicParams: { id: 'id' }, confirm: true, isReload: true, api: energyConsumption.del, }, ], }, formConfig: { schemas: [ { field: 'year', label: '年份', component: 'NsDatePicker', componentProps: { picker: 'year', valueFormat: 'YYYY', defaultValue: selectYear.value.format('YYYY'), }, }, ], params: {}, }, rowKey: 'id', }); // 获取表格数据 const getTableList = () => { fetch(energyConsumption.pageList , queryParams.value).then((res) => { data.value = res.data.records }); }; // 分页器 const onChange = (pageNumber: number,size: number) => { queryParams.value.pageNum = pageNumber; queryParams.value.pageSize = size; mainRef.value?.nsTableRef.reload(); }; // 计算碳排切换 const changeRadio = (e) => { if(e.target.value === 0){ isRequired.value = true }else{ isRequired.value = false } }; // 点击确定提交 const onSubmit = () => { formRef.value .validate() .then(() => { console.log('values', formState, toRaw(formState)); if(formState.value.unit){ formState.value.unit = formState.value.unit.join(',') } if(formState.value.id){ fetch(energyConsumption.update , formState.value).then((res) => { visible.value = false formState.value = {} message.success('操作成功!'); mainRef.value?.nsTableRef.reload(); }); }else{ fetch(energyConsumption.creat , formState.value).then((res) => { if(res.data === '新增数据已存在'){ visible.value = false NsMessage.warning(res.data); }else{ visible.value = false formState.value = {} message.success('操作成功!'); mainRef.value?.nsTableRef.reload(); } }); } }) .catch(error => { console.log('error', error); }); }; // 获取字典值 const getDictList = () => { // 获取排放类型的数据 fetch(energyConsumption.getDicList , {grp: 'EMISSION_TYPE'}).then((res) => { emissionTypeDic.value = res.data }); // 获取计量单位的数据 fetch(carbonEmissionFactorLibrary.dictionaryUnitManagement, { grp: 'MEASUREMENT_UNIT'}).then((res) => { measurementUnit.value = res.data measurementUnit.value = measurementUnit.value.map(item => ({ value: item.id, label: item.cnValue, children: item.children ? item.children.map(child => ({ value: child.id, label: child.cnValue })) : [] })); }); // 获取自动采集节点的数据 fetch(group.queryDeviceGroupTree, { energyType: 'ELECTRICITY_USAGE',orgId: orgId.value }).then((res) => { treeData.value = res.data treeData.value = treeData.value.map(item => ({ value: item.id, label: item.pointName, children: item.children ? item.children.map(child => ({ value: child.id, label: child.pointName })) : [] })); }); } // 点击新增按钮 const addNewData = () => { getDictList() visible.value = true } // 点击编辑按钮 const editData = (record) =>{ getDictList() visible.value = true fetch(energyConsumption.findById , {id : record.id }).then((res) => { if(res.data.unit){ res.data.unit = res.data.unit.split(',') } formState.value = res.data }); }; // 点击删除 const delData = (record) => { Modal.confirm({ title: '警告', content: '确定要删除吗?', okText: '确定', okType: 'primary', cancelText: '取消', onOk() { fetch(energyConsumption.del , {id : record.id }).then((res) => { message.success('操作成功!'); mainRef.value?.nsTableRef.reload(); }); }, onCancel() { console.log('Cancel'); }, }); } // 关闭新增抽屉 const onClose = () => { visible.value = false; formState.value = {} formRef.value.resetFields(); }; // 点击上传凭证按钮 const uploadVoucher = () => { openUpload.value = true; }; // 上传凭证弹窗点击确定 const handleOk = (e: MouseEvent) => { console.log(e); openUpload.value = false; }; // 上传凭证相关方法及变量 const fileList = ref([]); const handleChange = (info: UploadChangeParam) => { const status = info.file.status; if (status !== 'uploading') { console.log(info.file, info.fileList); } if (status === 'done') { message.success(`${info.file.name} 文件上传成功`); } else if (status === 'error') { message.error(`${info.file.name} 文件上传失败`); } }; function handleDrop(e: DragEvent) { console.log(e); } // 关闭上传凭证弹窗 const closeOpenUpload = () =>{ openUpload.value = false; }; </script> <style scoped lang="less"> ::v-deep .ant-table-title{ display: flex; } ::v-deep .ant-table-container{ padding: 0px 16px; } .buttonGroup{ margin-left: 1vw; width: 30vw; display: flex; justify-content: space-around; } </style> <style scoped> th.column-money, td.column-money { text-align: right !important; } </style>