taskEvaluationStart.vue 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886
  1. <template>
  2. <div class="evaluationStartNFrom">
  3. <el-dialog title="考评目标详情" v-model="dialogVisible" :fullscreen="true" :close-on-click-modal="false">
  4. <div class="startDetail">
  5. <p class="starttitleSty">单据信息:</p>
  6. <el-row class="danjuMsg">
  7. <el-col :span="6">
  8. <div class="danjuMsg_data">
  9. <span class="data_tit">业务编号:</span>
  10. <span>{{receiptMsg.code}}</span>
  11. </div>
  12. <div class="danjuMsg_data">
  13. <span class="data_tit">创建日期:</span>
  14. <span>{{receiptMsg.createDate}}</span>
  15. </div>
  16. </el-col>
  17. <el-col :span="6">
  18. <div class="danjuMsg_data">
  19. <span class="data_tit">业务简述:</span>
  20. <span>{{receiptMsg.des}}</span>
  21. </div>
  22. <div class="danjuMsg_data">
  23. <span class="data_tit">业务类别:</span>
  24. <span>{{receiptMsg.type}}</span>
  25. </div>
  26. </el-col>
  27. <el-col :span="6">
  28. <div class="danjuMsg_data">
  29. <span class="data_tit">流程状态:</span>
  30. <span>{{receiptMsg.stage}}</span>
  31. </div>
  32. <div class="danjuMsg_data">
  33. <span class="data_tit">年度:</span>
  34. <span>{{receiptMsg.year}}</span>
  35. </div>
  36. </el-col>
  37. <el-col :span="6">
  38. <div class="danjuMsg_data">
  39. <span class="data_tit">创建人:</span>
  40. <span>{{receiptMsg.createName}}</span>
  41. </div>
  42. <div class="danjuMsg_data">
  43. <span class="data_tit">单据状态:</span>
  44. <span>{{receiptMsg.recStage}}</span>
  45. </div>
  46. </el-col>
  47. </el-row>
  48. <div class="monthQuarterYear">
  49. <el-tabs v-model="activeName" class="tableMain" @tab-click="handleClick">
  50. <el-tab-pane v-for="it in stageData" :key="it.id" :label="it.stageName" :name="it.stageCode">
  51. <div class="detailsHeader">
  52. <div class="headerRight">
  53. <div class="seachFor">
  54. <el-input v-model="compNameSa" placeholder="请输入单位名称"
  55. @keyup.enter="getTableData(addstageId)"></el-input>
  56. <!-- <el-icon :size="20" color="#3B7AD1" @click="getTableData(isClickTagId)"><Search /></el-icon> -->
  57. </div>
  58. <!-- <div class="tableBtn add" @click="addTableDetail"
  59. v-if="activeName === 'ZDZX' || activeName === 'GLSX'">
  60. <img :src="addIcon" alt="">
  61. <span>新增</span>
  62. </div>
  63. <div class="tableBtn save" @click="saveAddDetail"
  64. v-if="activeName === 'ZDZX' || activeName === 'GLSX'">
  65. <img :src="saveIcon" alt="">
  66. <span>保存</span>
  67. </div> -->
  68. <div class="tableBtn save" @click="saveDetail" v-if="tabName === 'first'">
  69. <img :src="saveIcon" alt="">
  70. <span>保存</span>
  71. </div>
  72. <div class="tableBtn import" @click="handleImport" v-if="tabName === 'first'">
  73. <img :src="importIcon" alt="">
  74. <span>导入</span>
  75. </div>
  76. <div class="tableBtn export" @click="handleExport" v-if="tabName === 'first'">
  77. <img :src="exportIcon" alt="">
  78. <span>导出</span>
  79. </div>
  80. </div>
  81. </div>
  82. <el-table :data="monthQuarterYearData" style="width: 100%" ref="monthQuarterYearTT"
  83. :border="true" v-if="binSectionCode === 'QQ' && activeName ==='QQXM'">
  84. <el-table-column type="index" label="排名" align="center"></el-table-column>
  85. <el-table-column label="考评单位" prop="organizationShortName" width="300" />
  86. <el-table-column label="发展绩效" align="center">
  87. <el-table-column label="新能源发展" align="center">
  88. <el-table-column label="核准(备案)目标容量" align="center" width="180">
  89. <template #default="scope">
  90. <el-input-number v-model="scope.row['XNYFZ_HZ']" :precision="2"
  91. :step="0.1" />
  92. </template>
  93. </el-table-column>
  94. <el-table-column label="投资决策目标容量" align="center">
  95. <el-table-column label="合计" align="center" width="180">
  96. <template #default="scope">
  97. <el-input-number v-model="scope.row['XNYFZ_HJ']" :precision="2"
  98. :step="0.1" />
  99. </template>
  100. </el-table-column>
  101. <el-table-column label="已核准(备案)" align="center" width="180">
  102. <template #default="scope">
  103. <el-input-number v-model="scope.row['XNYFZ_YHZ']" :precision="2"
  104. :step="0.1" />
  105. </template>
  106. </el-table-column>
  107. <el-table-column label="待核准(备案)" align="center">
  108. <el-table-column label="已获取" align="center" width="180">
  109. <template #default="scope">
  110. <el-input-number v-model="scope.row['XNYFZ_YHQ']" :precision="2"
  111. :step="0.1" />
  112. </template>
  113. </el-table-column>
  114. <el-table-column label="待获取" align="center" width="180">
  115. <template #default="scope">
  116. <el-input-number v-model="scope.row['XNYFZ_DHQ']" :precision="2"
  117. :step="0.1" />
  118. </template>
  119. </el-table-column>
  120. </el-table-column>
  121. </el-table-column>
  122. </el-table-column>
  123. <el-table-column label="常规能源发展" align="center">
  124. <el-table-column label="核准(备案)目标容量" align="center" width="180">
  125. <template #default="scope">
  126. <el-input-number v-model="scope.row['CGNYFZ_HZ']" :precision="2"
  127. :step="0.1" />
  128. </template>
  129. </el-table-column>
  130. <el-table-column label="投资决策目标容量" align="center">
  131. <el-table-column label="已核准(备案)" align="center" width="180">
  132. <template #default="scope">
  133. <el-input-number v-model="scope.row['CGNYFZ_YHZ']" :precision="2"
  134. :step="0.1" />
  135. </template>
  136. </el-table-column>
  137. <el-table-column label="待核准(备案)" align="center" width="180">
  138. <template #default="scope">
  139. <el-input-number v-model="scope.row['CGNYFZ_DHZ']" :precision="2"
  140. :step="0.1" />
  141. </template>
  142. </el-table-column>
  143. </el-table-column>
  144. <el-table-column label="火电水电项目阶段性工作目标" align="center" width="220">
  145. <template #default="scope">
  146. <el-input v-model="scope.row['CGNYFZ_JDGZ']" :rows="2" type="textarea">
  147. </el-input>
  148. </template>
  149. </el-table-column>
  150. </el-table-column>
  151. <el-table-column label="战略新兴产业发展" align="center" width="220">
  152. <template #default="scope">
  153. <el-input v-model="scope.row['ZLXXCY_FZ']" :rows="2" type="textarea">
  154. </el-input>
  155. </template>
  156. </el-table-column>
  157. <el-table-column label="投资计划" align="center">
  158. <el-table-column label="基建投资" align="center" width="220">
  159. <template #default="scope">
  160. <el-input v-model="scope.row['TZJH_JJTZ']" :rows="2" type="textarea">
  161. </el-input>
  162. </template>
  163. </el-table-column>
  164. <el-table-column label="非基建投资" align="center" width="220">
  165. <template #default="scope">
  166. <el-input v-model="scope.row['TZJH_FJJTZ']" :rows="2" type="textarea">
  167. </el-input>
  168. </template>
  169. </el-table-column>
  170. </el-table-column>
  171. </el-table-column>
  172. </el-table>
  173. <el-table :data="monthQuarterYearData" style="width: 100%" ref="monthQuarterYearTT"
  174. :border="true" v-else>
  175. <el-table-column type="index" label="排名" align="center"></el-table-column>
  176. <el-table-column label="考评单位" prop="organizationShortName" width="300" />
  177. <el-table-column v-for="(it, index) in monthQuarterYearHeader" :key="index"
  178. :label="it.name" align="center">
  179. <el-table-column v-for="(iv, index) in it.children" :key="index" :label="iv.key"
  180. align="center" width="150" sortable
  181. :sort-method="(a,b)=>sortMethods(a,b,iv.code)">
  182. <template #default="scope">
  183. <el-select v-model="scope.row[iv.code]" placeholder="请选择审核状态"
  184. v-if="scope.row['IS_LH_'+iv.code] === '3'">
  185. <el-option v-for="item in statusData" :key="item.id" :label="item.name"
  186. :value="item.id">
  187. </el-option>
  188. </el-select>
  189. <el-input v-model="scope.row[iv.code]"
  190. v-else-if="scope.row['IS_LH_'+iv.code] === '2'"></el-input>
  191. <el-input-number v-model="scope.row[iv.code]" :precision="2" :step="0.1"
  192. v-else />
  193. </template>
  194. </el-table-column>
  195. </el-table-column>
  196. </el-table>
  197. </el-tab-pane>
  198. </el-tabs>
  199. <div class="tableSeach">
  200. <div class="seachType" v-for="item in titleMsgArr" :key="item.isName"
  201. :class="item.showClick? 'seachTypeCha':''" @click="changType(item)">
  202. <img :src="item.img" alt="" v-if="!item.showClick">
  203. <img :src="item.clickImg" alt="" v-else>
  204. <p :style="item.showClick? 'color: #3B7AD1' : ''">{{item.isName}}</p>
  205. </div>
  206. </div>
  207. </div>
  208. <div v-if="tabName === 'first'">
  209. <p class="starttitleSty">审批意见:</p>
  210. <el-input v-model="descMsg" :rows="3" type="textarea" placeholder="请输入审批意见"></el-input>
  211. </div>
  212. </div>
  213. <!-- <template #footer>
  214. <span class="dialog-footer">
  215. <el-button type="primary" @click="dialogVisible = false">取 消</el-button>
  216. </span>
  217. </template> -->
  218. <template #footer>
  219. <span class="dialog-footer" v-if="tabName === 'first'">
  220. <el-button type="primary" @click="examineAndApprove('agree')">同 意</el-button>
  221. <el-button @click="examineAndApprove('reject')">拒 绝</el-button>
  222. </span>
  223. </template>
  224. </el-dialog>
  225. <import-dailog ref="importPage" @successImport="successImport"></import-dailog>
  226. </div>
  227. </template>
  228. <script>
  229. import importDailog from '../importPage/importDailog.vue'
  230. import {
  231. apiGetgetResponsibilityInfoList,
  232. apiGetbinsectionList,
  233. apiGetbinstageList,
  234. apiGetExportMsg,
  235. apiPostIsdoAction,
  236. apiPostupdateResponsibilityInfo,
  237. apiGetHeaderDeptResponsibility
  238. } from '../../api/api'
  239. import * as XLSX from 'xlsx'
  240. import {
  241. saveAs
  242. } from 'file-saver'
  243. import * as XLSXD from 'xlsx-js-style'
  244. import sectionDef from '../../assets/benchmarkImg/sectionDef.png'
  245. import sectionCha from '../../assets/benchmarkImg/sectionCha.png'
  246. import addIcon from '../../assets/btnIcon/add.png'
  247. import saveIcon from '../../assets/btnIcon/save.png'
  248. import exportIcon from '../../assets/btnIcon/export.png'
  249. import importIcon from '../../assets/btnIcon/import.png'
  250. export default {
  251. components: {
  252. importDailog
  253. },
  254. data() {
  255. return {
  256. dialogVisible: false,
  257. activeName: '',
  258. monthQuarterYearData: [],
  259. monthQuarterYearHeader: [],
  260. isClickTagId: '',
  261. compNameSa: '',
  262. receiptMsg: {
  263. code: '',
  264. des: '',
  265. stage: '',
  266. createName: '',
  267. createDate: '',
  268. type: '',
  269. year: '',
  270. recStage: ''
  271. },
  272. rowMsg: {},
  273. moduleData: [],
  274. stageData: [],
  275. titleMsgArr: [],
  276. statusData: [],
  277. binSectionStr: '',
  278. binSectionCode: '',
  279. addIcon: addIcon,
  280. saveIcon: saveIcon,
  281. exportIcon: exportIcon,
  282. importIcon: importIcon,
  283. addstageId: '',
  284. instanceChild: {},
  285. tastbizKey: '',
  286. taskDefKey: '',
  287. descMsg: '',
  288. tabName: ''
  289. }
  290. },
  291. created() {
  292. this.statusData = [{
  293. name: '已确认',
  294. id: '1'
  295. },
  296. {
  297. name: '待确认',
  298. id: '0'
  299. },
  300. {
  301. name: '不合格',
  302. id: '-1'
  303. }
  304. ]
  305. },
  306. methods: {
  307. init(row, allData, tabVal) {
  308. this.dialogVisible = true
  309. this.instanceChild = allData
  310. this.tastbizKey = allData.bizKey
  311. this.taskDefKey = allData.defKey
  312. this.getevalHeaderDetails(this.tastbizKey, this.taskDefKey)
  313. this.getModelData(this.taskDefKey)
  314. this.rowMsg = row
  315. this.tabName = tabVal
  316. },
  317. sortMethods(a, b, it) {
  318. if (a[it] < b[it]) {
  319. return -1
  320. }
  321. },
  322. //获取头部详情
  323. getevalHeaderDetails(id) {
  324. let that = this
  325. let params = {
  326. id: id
  327. }
  328. apiGetHeaderDeptResponsibility(params).then(datas => {
  329. that.getDataMsg(datas)
  330. })
  331. },
  332. getDataMsg(datas) {
  333. if (datas && datas.data) {
  334. let item = datas.data
  335. this.receiptMsg = {
  336. code: item.responsibilityCode,
  337. des: item.des,
  338. stage: item.stage,
  339. createName: item.createName,
  340. createDate: item.createTime,
  341. type: item.checkCycle === 'YDKP' ? '月度考评' : item.checkCycle === 'JDKP' ? '季度考评' : '年度考评',
  342. year: item.year,
  343. recStage: '有效'
  344. }
  345. }
  346. },
  347. // 获取业务属性
  348. getModelData() {
  349. let that = this
  350. that.titleMsgArr = []
  351. let params = {
  352. type: '3'
  353. }
  354. apiGetbinsectionList(params).then(datas => {
  355. if (datas && datas.data) {
  356. that.moduleData = datas.data
  357. that.moduleData.forEach(item => {
  358. let obj = {
  359. id: item.id,
  360. isName: item.sectionName === '新能源(光电)' ? '新能源光电' : item
  361. .sectionName === '新能源(风电)' ? '新能源风电' : item.sectionName,
  362. isNameEn: item.sectionCode,
  363. showClick: false,
  364. isClass: 'sectionDef',
  365. img: sectionDef,
  366. isClassC: 'sectionCha',
  367. clickImg: sectionCha
  368. }
  369. that.titleMsgArr.push(obj)
  370. })
  371. that.titleMsgArr[0].showClick = true
  372. that.binSectionStr = that.titleMsgArr[0].id
  373. that.binSectionCode = that.titleMsgArr[0].isNameEn
  374. that.getStageData()
  375. }
  376. })
  377. },
  378. //根据业务属性获取业务阶段
  379. getStageData() {
  380. let that = this
  381. let params = {
  382. type: '2'
  383. }
  384. apiGetbinstageList(params).then(datas => {
  385. if (datas && datas.data) {
  386. that.stageData = datas.data
  387. that.activeName = datas.data[0].stageCode
  388. that.addstageId = datas.data[0].id
  389. that.getTableData(datas.data[0].id)
  390. }
  391. })
  392. },
  393. handleClick(val) {
  394. this.titleMsgArr.forEach(it =>{
  395. it.showClick = false
  396. if (val.props.name === 'QQXM') {
  397. if (it.isNameEn === 'QQ') {
  398. it.showClick = true
  399. this.binSectionStr = it.id
  400. }
  401. } else if (val.props.name === 'JJXM') {
  402. if (it.isNameEn === 'JJ') {
  403. it.showClick = true
  404. this.binSectionStr = it.id
  405. }
  406. } else if (val.props.name === 'GLSX') {
  407. if (it.isNameEn === 'GLSX') {
  408. it.showClick = true
  409. this.binSectionStr = it.id
  410. }
  411. } else if (val.props.name === 'ZDZX') {
  412. if (it.isNameEn === 'ZDZX') {
  413. it.showClick = true
  414. this.binSectionStr = it.id
  415. }
  416. } else if (val.props.name === 'KJCX') {
  417. if (it.isNameEn === 'KJCX') {
  418. it.showClick = true
  419. this.binSectionStr = it.id
  420. }
  421. } else {
  422. if (it.isNameEn === 'HD') {
  423. it.showClick = true
  424. this.binSectionStr = it.id
  425. }
  426. }
  427. })
  428. let stageId = ''
  429. this.activeName = val.props.name
  430. console.log('activeName', this.activeName)
  431. this.stageData.forEach(it => {
  432. if (it.stageCode === val.props.name) {
  433. stageId = it.id
  434. this.addstageId = it.id
  435. }
  436. })
  437. this.getTableData(stageId)
  438. },
  439. //获取表格数据
  440. getTableData(id) {
  441. let that = this
  442. let params = {
  443. responsibilityId: that.tastbizKey,
  444. binSection: that.binSectionStr,
  445. binStage: id,
  446. organizationShortName: that.compNameSa
  447. }
  448. apiGetgetResponsibilityInfoList(params).then(datas => {
  449. if (datas && datas.data) {
  450. if (datas.data.title) {
  451. let header = []
  452. for (let i in datas.data.title) {
  453. let obj = {
  454. name: i,
  455. children: datas.data.title[i]
  456. }
  457. header.push(obj)
  458. }
  459. that.monthQuarterYearHeader = header
  460. }
  461. that.monthQuarterYearData = datas.data.value
  462. }
  463. })
  464. },
  465. changType(data) {
  466. this.titleMsgArr.forEach(it => {
  467. it.showClick = false
  468. if (it.isName === data.isName) {
  469. it.showClick = true
  470. this.binSectionStr = it.id
  471. this.binSectionCode = data.isNameEn
  472. }
  473. })
  474. let stageId = ''
  475. this.stageData.forEach(it => {
  476. if (it.stageCode === this.activeName) {
  477. stageId = it.id
  478. }
  479. })
  480. this.getTableData(stageId)
  481. },
  482. saveDetail() {
  483. let that = this
  484. apiPostupdateResponsibilityInfo(that.monthQuarterYearData).then(datas => {
  485. if (datas) {
  486. if (datas.message === '成功') {
  487. that.$message({
  488. message: '考评目标详情信息保存成功',
  489. type: 'success'
  490. });
  491. } else {
  492. that.$message({
  493. message: datas.message,
  494. type: 'error'
  495. });
  496. }
  497. that.getTableData(that.addstageId)
  498. }
  499. })
  500. },
  501. handleImport() {
  502. this.$refs.importPage.upload.title = "考评目标详情信息导入"
  503. this.$refs.importPage.upload.open = true
  504. this.$refs.importPage.upload.url = '/responsibility-indicator-info/import-excel'
  505. },
  506. successImport(val) {
  507. that.getTableData(that.addstageId)
  508. },
  509. handleExport() {
  510. let that = this
  511. let url = 'responsibility-indicator-info/download-excel'
  512. let params = {
  513. responsibilityId: that.tastbizKey,
  514. binSection: that.binSectionStr,
  515. binStage: that.addstageId
  516. }
  517. apiGetExportMsg(url, params).then(datas => {
  518. let blob = new Blob([datas])
  519. saveAs(blob, '考评目标详情数据导出.xlsx')
  520. }).catch((r) => {
  521. console.error(r)
  522. })
  523. },
  524. examineAndApprove(type) {
  525. let that = this
  526. let actionCS = ''
  527. if (type === 'agree') {
  528. if (that.rowMsg.taskType === 'SIGN') {
  529. actionCS = 'signAgree'
  530. } else if (that.rowMsg.taskType === 'NORMAL') {
  531. actionCS = 'agree'
  532. }
  533. } else {
  534. // if (that.rowMsg.taskType === 'SIGN') {
  535. // actionCS = 'signReject'
  536. // } else if (that.rowMsg.taskType === 'NORMAL') {
  537. // }
  538. actionCS = 'reject'
  539. }
  540. let params = {
  541. taskId: that.rowMsg.id, //任务ID
  542. nodeId: that.rowMsg.nodeId, //节点ID
  543. action: actionCS, //固定值
  544. instanceId: that.rowMsg.instId, //流程实例ID
  545. opinion: that.descMsg, //审批意见
  546. iamCode: window.localStorage.getItem('code'), //认证后code值
  547. taskName: that.rowMsg.name,
  548. defKey: that.instanceChild.defKey,
  549. bizKey: that.instanceChild.bizKey
  550. }
  551. apiPostIsdoAction(params).then(datas => {
  552. if (datas && datas.data) {
  553. if (datas.data.isOk) {
  554. that.$message({
  555. message: datas.data.data,
  556. type: 'success'
  557. })
  558. that.dialogVisible = false
  559. that.$emit('approveMsg', datas.data.isOk)
  560. } else {
  561. that.$message({
  562. message: datas.data.msg,
  563. type: 'error'
  564. })
  565. }
  566. }
  567. })
  568. },
  569. }
  570. }
  571. </script>
  572. <style lang="less">
  573. .evaluationStartNFrom {
  574. .el-overlay {
  575. .el-dialog {
  576. // margin-top: 7vh;
  577. .el-dialog__body {
  578. padding: 0 20px !important;
  579. .startDetail {
  580. .starttitleSty {
  581. font-size: 18px;
  582. font-family: Microsoft YaHei;
  583. font-weight: bold;
  584. color: #3B7AD1;
  585. // line-height: 12px;
  586. margin: 20px 0 20px 10px;
  587. }
  588. .danjuMsg {
  589. border: 1px solid #D6DBEA;
  590. padding: 10px 20px;
  591. border-radius: 10px;
  592. // margin-bottom: 20px;
  593. .danjuMsg_data {
  594. padding: 5px 0 10px 0;
  595. .data_tit {
  596. margin-right: 10px;
  597. font-weight: bold;
  598. font-size: 14px;
  599. font-family: Microsoft YaHei;
  600. color: #8991B0;
  601. }
  602. .data_tit_wd {
  603. display: inline-block;
  604. width: 90px;
  605. }
  606. .el-form-item--small {
  607. .el-input {
  608. height: 25px;
  609. width: 160px;
  610. }
  611. margin-bottom: 0;
  612. .el-input-number {
  613. height: 25px;
  614. .el-input-number__decrease,
  615. .el-input-number__increase {
  616. right: -39px;
  617. }
  618. }
  619. }
  620. }
  621. }
  622. .el-select,
  623. .el-input {
  624. width: 100%;
  625. }
  626. .monthQuarterYear {
  627. display: flex;
  628. width: 100%;
  629. margin-top: 20px;
  630. .tableMain {
  631. width: calc(100% - 100px);
  632. .el-tabs__header {
  633. .el-tabs__nav {
  634. .el-tabs__item {
  635. font-size: 18px;
  636. font-family: Microsoft YaHei;
  637. font-weight: bold;
  638. margin: 0 10px;
  639. color: #8991B0;
  640. }
  641. .is-active {
  642. font-size: 18px;
  643. font-family: Microsoft YaHei;
  644. font-weight: bold;
  645. color: #3B7AD1;
  646. margin: 0 10px;
  647. }
  648. }
  649. }
  650. .detailsHeader {
  651. width: 100%;
  652. display: flex;
  653. .headerRight {
  654. display: flex;
  655. justify-content: end;
  656. width: 100%;
  657. margin-bottom: 5px;
  658. .seachFor {
  659. display: flex;
  660. .el-input {
  661. height: 30px;
  662. .el-input__inner {
  663. height: 30px;
  664. }
  665. .el-input__suffix {
  666. .el-select__caret {
  667. line-height: 30px;
  668. }
  669. }
  670. }
  671. .el-icon {
  672. margin: 5px 10px 0 10px;
  673. cursor: pointer;
  674. }
  675. }
  676. .tableBtn {
  677. display: flex;
  678. height: 20px;
  679. margin: 5px 10px 0 10px;
  680. // width: 5%;
  681. width: fit-content;
  682. img {
  683. margin-right: 5px;
  684. margin-top: 1px;
  685. }
  686. span {
  687. width: 35px;
  688. display: inline-block;
  689. font-size: 14px;
  690. font-family: Microsoft YaHei;
  691. font-weight: 400;
  692. }
  693. }
  694. .add {
  695. cursor: pointer;
  696. span {
  697. color: #3B7AD1;
  698. }
  699. }
  700. .save {
  701. cursor: pointer;
  702. span {
  703. color: #50C14E;
  704. }
  705. }
  706. .import {
  707. cursor: pointer;
  708. span {
  709. color: #ce1e78;
  710. }
  711. }
  712. .export {
  713. cursor: pointer;
  714. span {
  715. color: #2baa8a;
  716. }
  717. }
  718. }
  719. }
  720. .el-table {
  721. .el-table__header-wrapper {
  722. .el-table__header {
  723. .el-table__cell {
  724. border-bottom: none !important;
  725. }
  726. thead {
  727. tr {
  728. th {
  729. .cell {
  730. line-height: 16px;
  731. }
  732. }
  733. }
  734. }
  735. }
  736. }
  737. .el-table__body-wrapper {
  738. height: 35vh !important;
  739. .el-scrollbar {
  740. .is-horizontal {
  741. .el-scrollbar__thumb {
  742. // width: 100% !important;
  743. }
  744. }
  745. .el-table__body {
  746. tr {
  747. td {
  748. padding: 0;
  749. .cell {
  750. background: #F6F7FA;
  751. line-height: 47px;
  752. height: 47px;
  753. }
  754. }
  755. td:hover {
  756. line-height: 45px;
  757. height: 45px;
  758. }
  759. }
  760. }
  761. }
  762. }
  763. .el-table--border .el-table__cell {
  764. border: none;
  765. }
  766. .el-table thead.is-group th.el-table__cell {
  767. background: transparent;
  768. }
  769. .tooltipCC {
  770. width: 180px;
  771. display: inline-block;
  772. overflow: hidden;
  773. text-overflow: ellipsis;
  774. white-space: nowrap;
  775. }
  776. }
  777. .el-pagination {
  778. margin-top: 20px;
  779. text-align: end;
  780. position: relative;
  781. }
  782. }
  783. .tableSeach {
  784. width: 88px;
  785. height: 63vh;
  786. margin-left: 10px;
  787. margin-top: 37px;
  788. border: 1px solid #D6DBEA;
  789. padding: 5px 0;
  790. border-radius: 5px;
  791. overflow-y: auto;
  792. .seachType {
  793. width: 78px;
  794. height: 78px;
  795. cursor: pointer;
  796. border-left: 3px solid transparent;
  797. img {
  798. margin-top: 17px;
  799. margin-left: 27px;
  800. }
  801. p {
  802. text-align: center;
  803. font-size: 14px;
  804. }
  805. }
  806. .seachTypeCha {
  807. background: #E6EBF5;
  808. cursor: pointer;
  809. border-left: 3px solid #3B7AD1;
  810. }
  811. }
  812. }
  813. }
  814. }
  815. .el-dialog__footer {
  816. .dialog-footer {
  817. display: flex;
  818. justify-content: center;
  819. .el-button {
  820. width: 180px !important;
  821. height: 40px !important;
  822. }
  823. }
  824. }
  825. }
  826. }
  827. }
  828. </style>