|
@@ -117,69 +117,62 @@
|
|
|
</el-table-column>
|
|
|
<el-table-column label="业务板块" prop="binSectionName" />
|
|
|
<el-table-column label="考评年度" prop="year" />
|
|
|
- <el-table-column label="生产经营评级" prop="scjyRate" width="180" />
|
|
|
- <el-table-column label="(年度安全环保评级" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span
|
|
|
- v-if="userMes.deptId !== '23031009'">{{scope.row.safetyEnvProtection}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.safetyEnvProtection" :min="0" />
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="否决事项" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span
|
|
|
- v-if="userMes.deptId !== '23031009'">{{scope.row.veto === 1 ? '是' : '否'}}</span>
|
|
|
- <el-select v-else v-model="scope.row.veto" placeholder="请选择" size="large"
|
|
|
- style="width: 100px">
|
|
|
- <el-option v-for="item in isPgoptions" :key="item.value" :label="item.label"
|
|
|
- :value="item.value" />
|
|
|
- </el-select>
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="净利润" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span v-if="userMes.deptId !== '23031009'">{{scope.row.netProfit}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.netProfit" :min="0" />
|
|
|
- </template>
|
|
|
+ <el-table-column label="生产经营评级" align="center">
|
|
|
+ <el-table-column label="年度安全环保评级" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.safetyEnvProtection" :min="0" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="否决事项" width="140">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-select v-model="scope.row.veto" placeholder="请选择" size="large"
|
|
|
+ style="width: 100px">
|
|
|
+ <el-option v-for="item in isPgoptions" :key="item.value"
|
|
|
+ :label="item.label" :value="item.value" />
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="净利润" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.netProfit" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="经营业绩考核综合得分%" width="180" align="center">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.compositeScore" :min="0" :max="100" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="生产经营评级" prop="scjyRate" width="120" />
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="经营业绩考核综合得分%)" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span v-if="userMes.deptId !== '23031009'">{{scope.row.compositeScore}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.compositeScore" :min="0"
|
|
|
- :max="100" />
|
|
|
- </template>
|
|
|
+ <el-table-column label="前期评级" align="center">
|
|
|
+ <el-table-column label="年度项目进度目标" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.annualTarget" :min="0" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="先进性指标考核得分有无加分" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-select v-model="scope.row.bonusPoint" placeholder="请选择" size="large"
|
|
|
+ style="width: 100px">
|
|
|
+ <el-option v-for="item in isPgoptions" :key="item.value"
|
|
|
+ :label="item.label" :value="item.value" />
|
|
|
+ </el-select>
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="前期评级" prop="qqRate" width="100" />
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="前期评级" prop="qqRate" width="180" />
|
|
|
- <el-table-column label="(年度项目进度目标" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span v-if="userMes.deptId !== '23031009'">{{scope.row.annualTarget}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.annualTarget" :min="0" />
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="先进性指标考核得分有无加分)" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span
|
|
|
- v-if="userMes.deptId !== '23031009'">{{scope.row.bonusPoint === 1 ? '是' : '否'}}</span>
|
|
|
- <el-select v-model="scope.row.bonusPoint" placeholder="请选择" size="large"
|
|
|
- style="width: 100px">
|
|
|
- <el-option v-for="item in isPgoptions" :key="item.value" :label="item.label"
|
|
|
- :value="item.value" />
|
|
|
- </el-select>
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="基建评级" prop="jjRate" />
|
|
|
- <el-table-column label="(基建工程综合得分排名" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span
|
|
|
- v-if="userMes.deptId !== '23031009'">{{scope.row.compositeScoreRaking}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.compositeScoreRaking" :min="0" />
|
|
|
- </template>
|
|
|
- </el-table-column>
|
|
|
- <el-table-column label="基建工程项目等级)" width="150">
|
|
|
- <template #default="scope">
|
|
|
- <span v-if="userMes.deptId !== '23031009'">{{scope.row.projectLevel}}</span>
|
|
|
- <el-input-number v-else v-model="scope.row.projectLevel" :min="0" />
|
|
|
- </template>
|
|
|
+ <el-table-column label="基建评级" align="center">
|
|
|
+ <el-table-column label="基建工程综合得分排名" width="160">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.compositeScoreRaking" :min="0" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="基建工程项目等级" width="150">
|
|
|
+ <template #default="scope">
|
|
|
+ <el-input-number v-model="scope.row.projectLevel" :min="0" />
|
|
|
+ </template>
|
|
|
+ </el-table-column>
|
|
|
+ <el-table-column label="基建评级" prop="jjRate" width="100" />
|
|
|
</el-table-column>
|
|
|
<el-table-column label="年度评级" prop="yearRate" />
|
|
|
<!-- fixed="right" align="center" -->
|
|
@@ -288,14 +281,16 @@
|
|
|
import importDailog from '../importPage/importDailog.vue'
|
|
|
import btns from '../elbuttonS.vue'
|
|
|
import seachs from '../seachGroup.vue'
|
|
|
- import ExcelJS from 'exceljs'
|
|
|
- import fileSave from 'file-saver'
|
|
|
+ import {
|
|
|
+ saveAs
|
|
|
+ } from 'file-saver'
|
|
|
import addIcon from '../../assets/btnIcon/add.png'
|
|
|
import saveIcon from '../../assets/btnIcon/save.png'
|
|
|
import deleteIcon from '../../assets/btnIcon/delete.png'
|
|
|
import exportIcon from '../../assets/btnIcon/export.png'
|
|
|
import importIcon from '../../assets/btnIcon/import.png'
|
|
|
import {
|
|
|
+ apiGetExportMsg,
|
|
|
apiGetorganizationratinglist,
|
|
|
apiorganizationratinggrade,
|
|
|
apiGetorganizationratingsave,
|
|
@@ -716,86 +711,25 @@
|
|
|
})
|
|
|
},
|
|
|
handleImport() {
|
|
|
- this.$refs.importPage.upload.title = "单位考评评级"
|
|
|
+ this.$refs.importPage.upload.title = "单位考评评级详情导入"
|
|
|
this.$refs.importPage.upload.open = true
|
|
|
- this.$refs.importPage.upload.url = '/organization-rating/import'
|
|
|
+ this.$refs.importPage.upload.url = `/organization-rating/importExcel`
|
|
|
},
|
|
|
successImport(val) {
|
|
|
this.getevaluRatingDiaList(that.rowObj, that.rowkeyId)
|
|
|
},
|
|
|
handleExport() {
|
|
|
- let data = this.evaluationRatingDiaData //接口返回数据
|
|
|
- const workbook = new ExcelJS.Workbook()
|
|
|
- const worksheet = workbook.addWorksheet('Sheet1')
|
|
|
- //根据数据自己调整
|
|
|
- let colums = []
|
|
|
- colums = [{
|
|
|
- header: 'ID',
|
|
|
- key: 'id',
|
|
|
- width: 26,
|
|
|
- hidden: true
|
|
|
- },
|
|
|
- {
|
|
|
- header: '考评单位',
|
|
|
- key: 'organizationShortName',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '考评单位ID',
|
|
|
- key: 'organizationId',
|
|
|
- width: 26,
|
|
|
- hidden: true
|
|
|
- },
|
|
|
- {
|
|
|
- header: '业务板块ID',
|
|
|
- key: 'binSection',
|
|
|
- width: 26,
|
|
|
- hidden: true
|
|
|
- },
|
|
|
- {
|
|
|
- header: '考评年度',
|
|
|
- key: 'year',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '生成经营评级',
|
|
|
- key: 'scjyRate',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '前期评级',
|
|
|
- key: 'qqRate',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '基建评级',
|
|
|
- key: 'jjRate',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '年度评级',
|
|
|
- key: 'yearRate',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- {
|
|
|
- header: '备注',
|
|
|
- key: 'remake',
|
|
|
- width: 26
|
|
|
- },
|
|
|
- ]
|
|
|
- worksheet.columns = colums
|
|
|
- worksheet.getRow(1).font = {
|
|
|
- size: 12,
|
|
|
- bold: true
|
|
|
+ let that = this
|
|
|
+ let url = 'organization-rating/exportExcel'
|
|
|
+ let params = {
|
|
|
+ binSection: that.businessStr,
|
|
|
+ year: that.rowObj.year
|
|
|
}
|
|
|
- worksheet.addRows(data)
|
|
|
-
|
|
|
- workbook.xlsx.writeBuffer().then(buffer => {
|
|
|
- //这里为type
|
|
|
- const blob = new Blob([buffer], {
|
|
|
- type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8'
|
|
|
- })
|
|
|
- fileSave(blob, `单位考评评级数据导出.xlsx`)
|
|
|
+ apiGetExportMsg(url, params).then(datas => {
|
|
|
+ let blob = new Blob([datas])
|
|
|
+ saveAs(blob, '单位考评评级详情导出.xlsx')
|
|
|
+ }).catch((r) => {
|
|
|
+ console.error(r)
|
|
|
})
|
|
|
},
|
|
|
}
|