performanceDeduction.vue 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553
  1. <template>
  2. <div class="app-container organization-index">
  3. <div class="title-container">
  4. <breadcrumb id="breadcrumb-container" class="breadcrumb-container" />
  5. </div>
  6. <div>
  7. <el-tabs v-model="activeTabName" @tab-click="tabClick" type="border-card">
  8. <el-tab-pane label="评估部绩效扣分" name="department">
  9. <div style="width: 100%; height: 50px;">
  10. <el-date-picker style="margin-right: 20px;float: left;" v-model="selectDate1" type="daterange"
  11. :picker-options="pickerOptions" format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd"
  12. range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" align="right">
  13. </el-date-picker>
  14. <el-select v-model="listQueryByDepartment.departmentId" filterable placeholder="接单部门"
  15. style=" width: 200px;margin-left: 10px;float: left;">
  16. <el-option v-for="(d, id) in allotDepartment" :label="d.name" :value="d.id"></el-option>
  17. </el-select>
  18. <el-button class="filter-item" style="margin-left: 10px;float: left;" type="primary"
  19. @click="searchList1()" round>搜索
  20. </el-button>
  21. <el-button class="filter-item" round type="success" @click="resetParams1()">重置
  22. </el-button>
  23. <el-button class="filter-item" round type="info" @click="exportMajorPerformanceDeductionVO()"
  24. :disabled="exportStatus">导出
  25. </el-button>
  26. </div>
  27. <el-table :data="departmentPerformanceDeduction" fit stripe highlight-current-row
  28. :header-row-style="{ color: '#333333', 'font-size': '14px' }" style=" width: 100%; float: right;
  29. border-left: 1px solid #ebeced;
  30. border-right: 1px solid #ebeced;
  31. color: #333333; font-size: 14px;">
  32. <el-table-column label="部门名称" width="150">
  33. <template slot-scope="{row}">
  34. <span>{{ row.departmentName }}</span>
  35. </template>
  36. </el-table-column>
  37. <el-table-column label="复审扣分">
  38. <el-table-column label="一般错误">
  39. <template slot-scope="{row}">
  40. <el-link type="danger" v-if="row.reCheckNormalMistakeScore > 0"
  41. @click="setListQueryParms('复审', 'normal', row.departmentId, listQueryByDepartment.startTime, listQueryByDepartment.endTime)">{{
  42. row.reCheckNormalMistakeScore }}</el-link>
  43. <span v-else>{{ row.reCheckNormalMistakeScore }}</span>
  44. </template>
  45. </el-table-column>
  46. <el-table-column label="较大错误">
  47. <template slot-scope="{row}">
  48. <el-link type="danger" v-if="row.reCheckHardMistakeScore > 0"
  49. @click="setListQueryParms('复审', 'hard', row.departmentId, listQueryByDepartment.startTime, listQueryByDepartment.endTime)">{{
  50. row.reCheckHardMistakeScore }}</el-link>
  51. <span v-else>{{ row.reCheckHardMistakeScore }}</span>
  52. </template>
  53. </el-table-column>
  54. <el-table-column label="重大错误">
  55. <template slot-scope="{row}">
  56. <el-link type="danger" v-if="row.reCheckFatalMistakeScore > 0"
  57. @click="setListQueryParms('复审', 'fatal', row.departmentId, listQueryByDepartment.startTime, listQueryByDepartment.endTime)">{{
  58. row.reCheckFatalMistakeScore }}</el-link>
  59. <span v-else>{{ row.reCheckFatalMistakeScore }}</span>
  60. </template>
  61. </el-table-column>
  62. </el-table-column>
  63. <el-table-column label="抽检扣分">
  64. <el-table-column label="一般错误">
  65. </el-table-column>
  66. <el-table-column label="较大错误">
  67. </el-table-column>
  68. <el-table-column label="重大错误">
  69. </el-table-column>
  70. </el-table-column>
  71. <el-table-column label="外部投诉">
  72. <el-table-column label="一般错误">
  73. </el-table-column>
  74. <el-table-column label="较大错误">
  75. </el-table-column>
  76. <el-table-column label="重大错误">
  77. </el-table-column>
  78. <el-table-column label="服务态度恶劣">
  79. </el-table-column>
  80. </el-table-column>
  81. <el-table-column label="内部投诉">
  82. <el-table-column label="一般错误">
  83. </el-table-column>
  84. <el-table-column label="较大错误">
  85. </el-table-column>
  86. <el-table-column label="重大错误">
  87. </el-table-column>
  88. <el-table-column label="服务态度恶劣">
  89. </el-table-column>
  90. </el-table-column>
  91. <el-table-column label="疑难项目加减分" width="120">
  92. </el-table-column>
  93. <el-table-column label="总经理加减分">
  94. </el-table-column>
  95. <el-table-column label="部门综合评分">
  96. </el-table-column>
  97. <el-table-column prop="allMistakeScore" label="扣分合计">
  98. </el-table-column>
  99. </el-table>
  100. </el-tab-pane>
  101. <el-tab-pane label="评估人员绩效扣分" name="evaluator">
  102. <div style="width: 100%; height: 50px;">
  103. <el-date-picker style="margin-right: 20px;float: left;" v-model="selectDate2" type="daterange"
  104. :picker-options="pickerOptions" format="yyyy 年 MM 月 dd 日" value-format="yyyy-MM-dd"
  105. range-separator="至" start-placeholder="开始日期" end-placeholder="结束日期" align="right">
  106. </el-date-picker>
  107. <el-select v-model="listQueryByEvaluator.departmentId" filterable placeholder="接单部门"
  108. style=" width: 200px;margin-left: 10px;float: left;">
  109. <el-option v-for="(d, id) in allotDepartment" :label="d.name" :value="d.id"></el-option>
  110. </el-select>
  111. <el-input v-model="listQueryByEvaluator.userName" placeholder="姓名" clearable
  112. style="margin-left: 20px;width: 200px;float: left;">
  113. </el-input>
  114. <el-button class="filter-item" style="margin-left: 10px;float: left;" type="primary"
  115. @click="searchList2()" round>搜索
  116. </el-button>
  117. <el-button class="filter-item" round type="success" @click="resetParams2()">重置
  118. </el-button>
  119. <el-button class="filter-item" round type="info"
  120. @click="exportMajorPerformanceDeductionByEvaluator()" :disabled="exportStatus">导出
  121. </el-button>
  122. </div>
  123. <el-table :data="evaluatorPerformanceDeduction" fit stripe highlight-current-row
  124. :header-row-style="{ color: '#333333', 'font-size': '14px' }" style=" width: 100%; float: right;
  125. border-left: 1px solid #ebeced;
  126. border-right: 1px solid #ebeced;
  127. color: #333333; font-size: 14px;">
  128. <el-table-column label="评估人员" width="150">
  129. <template slot-scope="{row}">
  130. <span>{{ row.userName }}</span>
  131. </template>
  132. </el-table-column>
  133. <el-table-column label="部门名称" width="150">
  134. <template slot-scope="{row}">
  135. <span>{{ row.departmentName }}</span>
  136. </template>
  137. </el-table-column>
  138. <el-table-column label="复审扣分">
  139. <el-table-column label="一般错误">
  140. <template slot-scope="{row}">
  141. <el-link type="danger" v-if="row.reCheckNormalMistakeScore > 0"
  142. @click="setListQueryParms('复审', 'normal', row.departmentId, listQueryByEvaluator.startTime, listQueryByEvaluator.endTime, row.userId)">{{
  143. row.reCheckNormalMistakeScore }}</el-link>
  144. <span v-else>{{ row.reCheckNormalMistakeScore }}</span>
  145. </template>
  146. </el-table-column>
  147. <el-table-column label="较大错误">
  148. <template slot-scope="{row}">
  149. <el-link type="danger" v-if="row.reCheckHardMistakeScore > 0"
  150. @click="setListQueryParms('复审', 'hard', row.departmentId, listQueryByEvaluator.startTime, listQueryByEvaluator.endTime, row.userId)">{{
  151. row.reCheckHardMistakeScore }}</el-link>
  152. <span v-else>{{ row.reCheckHardMistakeScore }}</span>
  153. </template>
  154. </el-table-column>
  155. <el-table-column label="重大错误">
  156. <template slot-scope="{row}">
  157. <el-link type="danger" v-if="row.reCheckFatalMistakeScore > 0"
  158. @click="setListQueryParms('复审', 'fatal', row.departmentId, listQueryByEvaluator.startTime, listQueryByEvaluator.endTime, row.userId)">{{
  159. row.reCheckFatalMistakeScore }}</el-link>
  160. <span v-else>{{ row.reCheckFatalMistakeScore }}</span>
  161. </template>
  162. </el-table-column>
  163. </el-table-column>
  164. <el-table-column label="抽检扣分">
  165. <el-table-column label="一般错误">
  166. </el-table-column>
  167. <el-table-column label="较大错误">
  168. </el-table-column>
  169. <el-table-column label="重大错误">
  170. </el-table-column>
  171. </el-table-column>
  172. <el-table-column label="外部投诉">
  173. <el-table-column label="一般错误">
  174. </el-table-column>
  175. <el-table-column label="较大错误">
  176. </el-table-column>
  177. <el-table-column label="重大错误">
  178. </el-table-column>
  179. <el-table-column label="服务态度恶劣">
  180. </el-table-column>
  181. </el-table-column>
  182. <el-table-column label="内部投诉">
  183. <el-table-column label="一般错误">
  184. </el-table-column>
  185. <el-table-column label="较大错误">
  186. </el-table-column>
  187. <el-table-column label="重大错误">
  188. </el-table-column>
  189. <el-table-column label="服务态度恶劣">
  190. </el-table-column>
  191. </el-table-column>
  192. <el-table-column prop="allMistakeScore" label="扣分合计">
  193. </el-table-column>
  194. </el-table>
  195. </el-tab-pane>
  196. </el-tabs>
  197. </div>
  198. <el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="70%"
  199. @open="getMajorPerformanceDeductionDetailVO()">
  200. <y-page-list-layout :get-page-list="getMajorPerformanceDeductionDetailVO" :page-list="pageData"
  201. :page-para="listQueryDetail">
  202. <template slot="left">
  203. <el-button class="filter-item" round type="info" @click="exportPerformanceDeductionDetail()">导出
  204. </el-button>
  205. </template>
  206. <parentTable ref="table" :data="pageData.records" slot="table" style="width: 100%;" :isBoard=800>
  207. <el-table-column label="项目编号" align="center">
  208. <template slot-scope="{row}">
  209. <span>{{ row.orderId }}</span>
  210. </template>
  211. </el-table-column>
  212. <el-table-column label="项目名称" align="center">
  213. <template slot-scope="{row}">
  214. <span v-if="row.financial">金融</span>
  215. <span v-else>非金融</span>
  216. </template>
  217. </el-table-column>
  218. <el-table-column label="项目名称" align="center">
  219. <template slot-scope="{row}">
  220. <span>{{ row.projectName }}</span>
  221. </template>
  222. </el-table-column>
  223. <el-table-column label="银行/单位" align="center">
  224. <template slot-scope="{row}">
  225. <span>{{ row.customerName }}</span>
  226. </template>
  227. </el-table-column>
  228. <el-table-column label="产品类型" align="center">
  229. <template slot-scope="{row}">
  230. <span>{{ row.productionType }}</span>
  231. </template>
  232. </el-table-column>
  233. <el-table-column label="产品号" align="center">
  234. <template slot-scope="{row}">
  235. <span>{{ row.productionNo }}</span>
  236. </template>
  237. </el-table-column>
  238. <el-table-column label="项目负责人" align="center">
  239. <template slot-scope="{row}">
  240. <span>{{ row.principalName }}</span>
  241. </template>
  242. </el-table-column>
  243. <el-table-column label="参与人" align="center">
  244. <template slot-scope="{row}">
  245. <span>{{ row.members }}</span>
  246. </template>
  247. </el-table-column>
  248. <el-table-column label="评估金额(万元)" align="center">
  249. <template slot-scope="{row}">
  250. <span>{{ row.evaluateAmount }}</span>
  251. </template>
  252. </el-table-column>
  253. <el-table-column label="评估目的" align="center">
  254. <template slot-scope="{row}">
  255. <span>{{ row.evaluateAim }}</span>
  256. </template>
  257. </el-table-column>
  258. <el-table-column label="扣分人" align="center">
  259. <template slot-scope="{row}">
  260. <span>{{ row.checkerName }}</span>
  261. </template>
  262. </el-table-column>
  263. <el-table-column label="错误个数" align="center">
  264. <template slot-scope="{row}">
  265. <span>{{ row.mistakeCount }}</span>
  266. </template>
  267. </el-table-column>
  268. <el-table-column label="加减分" align="center">
  269. <template slot-scope="{row}">
  270. <span>{{ row.mistakeScore }}</span>
  271. </template>
  272. </el-table-column>
  273. <el-table-column label="扣分时间" align="center">
  274. <template slot-scope="{row}">
  275. <span>{{ row.checkTime }}</span>
  276. </template>
  277. </el-table-column>
  278. <el-table-column label="扣分原因" align="center">
  279. <template slot-scope="{row}">
  280. <span>{{ row.reason }}</span>
  281. </template>
  282. </el-table-column>
  283. </parentTable>
  284. </y-page-list-layout>
  285. </el-dialog>
  286. </div>
  287. </template>
  288. <script>
  289. import Breadcrumb from '@/components/Breadcrumb'
  290. import YPageListLayout from '@/components/YPageListLayout'
  291. export default {
  292. name: 'majorPerformanceDeduction',
  293. components: {
  294. Breadcrumb,
  295. YPageListLayout
  296. },
  297. data() {
  298. return {
  299. activeTabName: 'department',
  300. dialogVisible: false,
  301. dialogTitle: null,
  302. listLoading: false,
  303. // 时间
  304. selectDate1: [],
  305. selectDate2: [],
  306. listQueryByDepartment: {
  307. page: 1,
  308. size: 10,
  309. current: 1,
  310. // 开始时间
  311. startTime: null,
  312. // 结束时间
  313. endTime: null,
  314. // 部门id
  315. departmentId: null
  316. },
  317. listQueryByEvaluator: {
  318. page: 1,
  319. size: 10,
  320. current: 1,
  321. // 开始时间
  322. startTime: null,
  323. // 结束时间
  324. endTime: null,
  325. // 部门id
  326. departmentId: null,
  327. // 评估人员姓名
  328. userName: null
  329. },
  330. listQueryDetail: {
  331. page: 1,
  332. size: 10,
  333. current: 1,
  334. // 审核轮次
  335. checkLoop: null,
  336. // 错误类型(normal、hard、fatal)
  337. mistakeType: null,
  338. // 开始时间
  339. startTime: null,
  340. // 结束时间
  341. endTime: null,
  342. // 部门id
  343. departmentId: null,
  344. principalId: null
  345. },
  346. // 接单部门
  347. allotDepartment: [],
  348. pickerOptions: {
  349. shortcuts: [{
  350. text: '最近一周',
  351. onClick(picker) {
  352. const end = new Date();
  353. const start = new Date();
  354. start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
  355. picker.$emit('pick', [start, end]);
  356. }
  357. }, {
  358. text: '最近一个月',
  359. onClick(picker) {
  360. const end = new Date();
  361. const start = new Date();
  362. start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
  363. picker.$emit('pick', [start, end]);
  364. }
  365. }, {
  366. text: '最近三个月',
  367. onClick(picker) {
  368. const end = new Date();
  369. const start = new Date();
  370. start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
  371. picker.$emit('pick', [start, end]);
  372. }
  373. }]
  374. },
  375. exportStatus: true,
  376. departmentPerformanceDeduction: [],
  377. evaluatorPerformanceDeduction: [],
  378. pageData: { records: [] },
  379. }
  380. },
  381. created() {
  382. this.selectDate1.push(this.getDefaultStartDate());
  383. this.selectDate1.push(this.getDefaultEndDate());
  384. this.selectDate2.push(this.getDefaultStartDate());
  385. this.selectDate2.push(this.getDefaultEndDate());
  386. this.getAllotDepartment();
  387. this.getMajorPerformanceDeductionVO();
  388. },
  389. methods: {
  390. getDefaultStartDate() {
  391. const currentDate = new Date();
  392. const currentYear = currentDate.getFullYear();
  393. var currentMonth = String(currentDate.getMonth()).padStart(2, "0");
  394. return currentYear + '-' + currentMonth + '-' + '23'
  395. },
  396. getDefaultEndDate() {
  397. const currentDate = new Date();
  398. const currentYear = currentDate.getFullYear();
  399. var currentMonth = String(currentDate.getMonth() + 1).padStart(2, "0");
  400. return currentYear + '-' + currentMonth + '-' + '22'
  401. },
  402. tabClick(tab, event) {
  403. if (tab.name === 'department') {
  404. this.getMajorPerformanceDeductionVO();
  405. }
  406. if (tab.name === 'evaluator') {
  407. this.getMajorPerformanceDeductionVOByEvaluator();
  408. }
  409. },
  410. // 条件查询
  411. searchList1() {
  412. this.getMajorPerformanceDeductionVO()
  413. },
  414. // 重置搜索条件
  415. resetParams1() {
  416. this.exportStatus = true;
  417. this.listQueryByDepartment = {
  418. // 重置分页
  419. page: 1,
  420. size: 10,
  421. // 开始时间
  422. startTime: null,
  423. // 结束时间
  424. endTime: null,
  425. // 部门id
  426. departmentId: null
  427. };
  428. this.selectDate1 = [];
  429. this.selectDate1.push(this.getDefaultStartDate());
  430. this.selectDate1.push(this.getDefaultEndDate());
  431. this.getMajorPerformanceDeductionVO();
  432. },
  433. getMajorPerformanceDeductionVO() {
  434. if (this.selectDate1) {
  435. this.listQueryByDepartment.startTime = this.selectDate1[0] + ' 00:00:00';
  436. this.listQueryByDepartment.endTime = this.selectDate1[1] + ' 23:59:59';
  437. }
  438. this.$api.statistical.getMajorPerformanceDeductionVO(this.listQueryByDepartment).then(res => {
  439. if (res.code === 200) {
  440. this.departmentPerformanceDeduction = res.data;
  441. if (this.listQueryByDepartment.startTime !== null && this.listQueryByDepartment.endTime !== null && res.data.length > 0) {
  442. this.exportStatus = false;
  443. } else {
  444. this.exportStatus = true;
  445. }
  446. }
  447. })
  448. },
  449. exportMajorPerformanceDeductionVO() {
  450. this.$utils.exportUtil(
  451. "major/statisticalStatement/department/getMajorPerformanceDeductionVO/export", this.listQueryByDepartment,
  452. "导出"
  453. );
  454. },
  455. // 获取部门下拉列表
  456. getAllotDepartment() {
  457. this.$api.department.allot('MAJOR_BUSINESS').then(res => {
  458. if (res.code === 200) {
  459. this.allotDepartment = res.data;
  460. }
  461. })
  462. },
  463. setListQueryParms(checkLoop, mistakeType, departmentId, startTime, endTime, userId) {
  464. this.dialogVisible = true;
  465. this.listQueryDetail.page = 1;
  466. this.listQueryDetail.size = 10;
  467. this.listQueryDetail.current = 1;
  468. this.listQueryDetail.checkLoop = checkLoop;
  469. this.listQueryDetail.mistakeType = mistakeType;
  470. this.listQueryDetail.departmentId = departmentId;
  471. this.listQueryDetail.startTime = startTime;
  472. this.listQueryDetail.endTime = endTime;
  473. if (userId) {
  474. this.listQueryDetail.principalId = userId;
  475. } else {
  476. this.listQueryDetail.principalId = null;
  477. }
  478. if (mistakeType === 'normal') {
  479. this.dialogTitle = checkLoop + ":一般错误列表";
  480. } else if (mistakeType === 'hard') {
  481. this.dialogTitle = checkLoop + ":较大错误列表";
  482. } else if (mistakeType === 'fatal') {
  483. this.dialogTitle = checkLoop + ":重大错误列表";
  484. } else {
  485. this.dialogTitle = "-";
  486. }
  487. },
  488. // 查询错误详情列表
  489. getMajorPerformanceDeductionDetailVO() {
  490. this.$api.statistical.getMajorPerformanceDeductionDetailVO(this.listQueryDetail).then(res => {
  491. if (res.code === 200) {
  492. this.pageData = res.data;
  493. }
  494. })
  495. },
  496. // 错误详情列表导出
  497. exportPerformanceDeductionDetail() {
  498. this.$utils.exportUtil(
  499. "major/statisticalStatement/getMajorPerformanceDeductionDetailVO/export", this.listQueryDetail,
  500. "导出"
  501. );
  502. },
  503. // 条件查询
  504. searchList2() {
  505. this.getMajorPerformanceDeductionVOByEvaluator()
  506. },
  507. // 重置搜索条件
  508. resetParams2() {
  509. this.exportStatus = true;
  510. this.listQueryByEvaluator = {
  511. // 重置分页
  512. page: 1,
  513. size: 10,
  514. // 开始时间
  515. startTime: null,
  516. // 结束时间
  517. endTime: null,
  518. // 部门id
  519. departmentId: null
  520. };
  521. this.selectDate2 = [];
  522. this.selectDate2.push(this.getDefaultStartDate());
  523. this.selectDate2.push(this.getDefaultEndDate());
  524. this.getMajorPerformanceDeductionVOByEvaluator();
  525. },
  526. // 评估人员绩效扣分查询
  527. getMajorPerformanceDeductionVOByEvaluator() {
  528. if (this.selectDate2) {
  529. this.listQueryByEvaluator.startTime = this.selectDate2[0] + ' 00:00:00';
  530. this.listQueryByEvaluator.endTime = this.selectDate2[1] + ' 23:59:59';
  531. }
  532. this.$api.statistical.getMajorPerformanceDeductionVOByEvaluator(this.listQueryByEvaluator).then(res => {
  533. if (res.code === 200) {
  534. this.evaluatorPerformanceDeduction = res.data;
  535. if (this.listQueryByEvaluator.startTime !== null && this.listQueryByEvaluator.endTime !== null && res.data.length > 0) {
  536. this.exportStatus = false;
  537. } else {
  538. this.exportStatus = true;
  539. }
  540. }
  541. })
  542. },
  543. exportMajorPerformanceDeductionByEvaluator() {
  544. this.$utils.exportUtil(
  545. "major/statisticalStatement/evaluator/getMajorPerformanceDeductionVO/export", this.listQueryByEvaluator,
  546. "导出"
  547. );
  548. }
  549. }
  550. }
  551. </script>