performanceDeduction.vue 34 KB

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