itdmXnJiesuan.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509
  1. <template>
  2. <div class="u-OA-jixiao">
  3. <div class="head">第五部分 试验虚拟结算</div>
  4. <table class="main-table">
  5. <tr>
  6. <td rowspan="6" style="width: 100px">市场部<br/>核准</td>
  7. <td class="title" style="width: 100px">核准<br/>虚拟结算额</td>
  8. <td class="content" style="width: 360px">
  9. <div>
  10. <div v-for="(item, index) in stepEdit.xnJiesuanE" :key="index">{{ item.typeName }}:{{ item.price }};</div>
  11. </div>
  12. </td>
  13. <td class="title white" style="width: 100px">核准<br/>虚拟结算毛利</td>
  14. <td class="content">
  15. <!-- <input v-model="stepEdit.xnMaoli" style="text-align: center" /> -->
  16. <div>
  17. <div v-for="(item, index) in stepEdit.xnJiesuanE" :key="index">{{ item.typeName }}:{{ item.price * 0.8 }};</div>
  18. </div>
  19. </td>
  20. </tr>
  21. <tr>
  22. <td class="title" style="width: 100px">核准<br/>合同总额</td>
  23. <td class="content" style="width: 360px">
  24. <input v-model="stepEdit.hetongZonge" style="text-align: center" :disabled="stepParameter.disabled"/>
  25. </td>
  26. <td class="title white" style="width: 100px">核准<br/>外协外购</td>
  27. <td class="content" style="width: 350px">
  28. <input v-model="stepEdit.waixieWaigou" style="text-align: center" :disabled="stepParameter.disabled"/>
  29. </td>
  30. </tr>
  31. <tr>
  32. <td class="title" style="width: 100px">销售提成<br/>基数</td>
  33. <td class="content" style="width: 360px">
  34. <input v-model="stepEdit.tichengJishu" style="text-align: center" :disabled="stepParameter.disabled"/>
  35. </td>
  36. <td class="title white" style="width: 100px">项目满意度</td>
  37. <td class="content" style="width: 350px">
  38. <el-input-number v-model="stepEdit.manyidu" :precision="0" :min="1" :max="100" label="项目满意度" :disabled="stepParameter.disabled"></el-input-number>
  39. </td>
  40. </tr>
  41. <tr>
  42. <td class="title" style="width: 100px">项目计算<br/>标准</td>
  43. <td class="content" style="width: 360px">
  44. <div>
  45. <div>虚拟结算量化标准</div>
  46. <div>0-5万:5%</div>
  47. <div>5-10万:4%</div>
  48. <div>10-50万:3%</div>
  49. <div>50万以上:2%</div>
  50. </div>
  51. </td>
  52. <td class="title white" style="width: 100px">项目绩效<br/>基数计算</td>
  53. <td class="content" style="width: 350px">
  54. <el-table :data="stepEdit.jixiaoData" style="width: 100%">
  55. <el-table-column type="index" label="序号"></el-table-column>
  56. <!-- <el-table-column prop="type" label="试验类型"></el-table-column> -->
  57. <el-table-column prop="typeName" label="试验类型"></el-table-column>
  58. <!-- <el-table-column prop="fenduan" label="合同分段"></el-table-column> -->
  59. <el-table-column prop="bili" label="分段比例"></el-table-column>
  60. <el-table-column prop="ticheng" label="分段提成"></el-table-column>
  61. <el-table-column prop="yue" label="分段余额"></el-table-column>
  62. </el-table>
  63. </td>
  64. </tr>
  65. <tr>
  66. <td class="title" style="width: 100px">项目得分<br/>(百分制)</td>
  67. <td class="content" style="width: 360px">
  68. <el-input-number v-model="stepEdit.fenshu" :precision="0" :min="1" :max="100" label="项目满意度" :disabled="stepParameter.disabled"></el-input-number>
  69. </td>
  70. <!-- <td class="content" style="width: 100px" colspan="2"></td> -->
  71. <td class="title white" style="width: 100px">虚拟结算<br/>绩效总额</td>
  72. <td class="content" style="width: 350px">
  73. <!-- 乘系数之后的数值数组 -->
  74. <!-- <div v-for="(item, index) in stepEdit.xnJixiaoZongeArr" :key="index">{{ item.typeName }}:{{ item.price }};</div> -->
  75. <!-- 乘满意度之后的总额 -->
  76. <div>{{ (stepEdit.xnJixiaoZonge * stepEdit.manyidu)/100 }}</div>
  77. </td>
  78. </tr>
  79. <tr>
  80. <td class="title" style="width: 100px">核准结论</td>
  81. <td class="content" style="width: 360px">
  82. <input v-model="stepEdit.reviewResult" style="text-align: center" :disabled="stepParameter.disabled"/>
  83. </td>
  84. <!-- <td class="content" style="width: 100px" colspan="2"></td> -->
  85. <td class="title white" style="width: 100px">核准人 </td>
  86. <td class="content" style="width: 350px">
  87. {{ stepParameter.fqUserName }}
  88. {{stepParameter.shenheTime}}
  89. <div class="btn" @click="submitSCReview()" :style="{'pointer-events':stepParameter.disabled?'none':'auto'}">保存</div>
  90. </td>
  91. </tr>
  92. <!-- 其余核准循环 -->
  93. <tr v-for="(item, index) in reviewLists" :key="index" :style="{'background-color': item.bgc}">
  94. <td class="" style="width: 100px;">{{item.title}}</td>
  95. <td class="title" style="width: 100px">{{item.name}}</td>
  96. <td class="content" style="width: 360px;">
  97. <div v-if="item.sort === '11' && !item.disabled">
  98. 考核系数:100%;(对应哪儿个) 实际积分:{{ (stepEdit.xnJixiaoZonge * stepEdit.manyidu)/100 }}
  99. </div>
  100. <input v-else v-model="item.reviewResult" style="text-align: center;width: 100%;" :disabled="item.disabled"/>
  101. </td>
  102. <!-- <td class="content" style="width: 100px" colspan="2"></td> -->
  103. <td class="title white" style="width: 100px">{{item.person}} </td>
  104. <td class="content" style="width: 350px;">
  105. {{ item.fqUserName }} {{item.shenheTime}}
  106. <div class="btn" @click="submitReview(item)" :style="{'pointer-events':item.disabled?'none':'auto'}">保存</div>
  107. </td>
  108. </tr>
  109. </table>
  110. </div>
  111. </template>
  112. <script>
  113. export default {
  114. name: 'itdmXnJiesuan',
  115. props: {
  116. tableData5: {
  117. type: Array,
  118. default: [],
  119. required: false
  120. }
  121. },
  122. data() {
  123. return {
  124. defineXishu: [
  125. { type: 0, xishu: 0.40 },
  126. { type: 1, xishu: 0.70 },
  127. { type: 2, xishu: 1 },
  128. ],
  129. // 获取的流程数据
  130. stepParameter: {
  131. id: null,
  132. disabled: true
  133. },
  134. // 数据编辑信息
  135. stepEdit: {
  136. xnJiesuanE: [],
  137. tichengJishu: null,
  138. manyidu: 100,
  139. fenshu: 100,
  140. jixiaoData: [],
  141. xnJixiaoZonge: null,
  142. // hasMYDJixiaoZonge: null,
  143. xnJixiaoZongeArr: [],
  144. reviewSC: null
  145. },
  146. // 评审信息
  147. reviewLists: [
  148. {
  149. title: '工程技术部核准',
  150. name: '核准结论',
  151. person: '核准人',
  152. bgc: '#E5E0EC',
  153. disabled: true,
  154. reviewResult: null,
  155. fqUserName: null,
  156. shenheTime: null,
  157. sort: '9',
  158. },
  159. {
  160. title: '财务部核准',
  161. name: '核准结论',
  162. person: '核准人',
  163. bgc: '#F2DCDB',
  164. disabled: true,
  165. reviewResult: null,
  166. fqUserName: null,
  167. shenheTime: null,
  168. sort: '10',
  169. },
  170. {
  171. title: '总经理审批核准',
  172. name: '批准结论',
  173. person: '总经理',
  174. bgc: '#E5B9B7',
  175. disabled: true,
  176. reviewResult: null,
  177. fqUserName: null,
  178. shenheTime: null,
  179. sort: '11',
  180. },
  181. {
  182. title: '归档',
  183. name: '合同信息',
  184. person: '核准人',
  185. bgc: '#DBEEF3',
  186. disabled: true,
  187. reviewResult: null,
  188. fqUserName: null,
  189. shenheTime: null,
  190. sort: '12',
  191. },
  192. ],
  193. // moniData: [
  194. // { type: 0, typeName: '气候试验', time: 1, unitPrice: 3, costPrice: 20000 },
  195. // { type: 0, typeName: '气候试验', time: 1, unitPrice: 3, costPrice: 30000 },
  196. // { type: 1, typeName: '力学试验', time: 1, unitPrice: 3, costPrice: 100000 },
  197. // { type: 1, typeName: '力学试验', time: 1, unitPrice: 3, costPrice: 200000 },
  198. // { type: 1, typeName: '力学试验', time: 1, unitPrice: 3, costPrice: 210000 },
  199. // { type: 2, typeName: '重要试验', time: 1, unitPrice: 3, costPrice: 100000 },
  200. // ]
  201. }
  202. },
  203. computed: {
  204. },
  205. watch: {
  206. tableData5: {
  207. handler(newV, oldV){
  208. if(newV && newV[0]){
  209. console.log(newV)
  210. var arrData = newV
  211. var obj = arrData.find(res => res.sort === '8')
  212. this.stepEdit = obj.saveData ? JSON.parse(obj.saveData) : this.stepEdit
  213. this.stepParameter = obj
  214. this.stepParameter.disabled = !(obj.dangqian && obj.isUpdate)
  215. if(arrData[0].saveData){
  216. // 计算核准虚拟结算额
  217. var xnJiesuanPrice = JSON.parse(arrData[0].saveData).xnJiesuanPrice
  218. this.stepEdit.xnJiesuanE = this.changeData(xnJiesuanPrice, 'costPrice')
  219. // 项目绩效基础计算
  220. this.computeJixiaoData()
  221. // 计算虚拟结算绩效总额
  222. this.computeJXXishuZonge()
  223. }
  224. // 核准循环赋值
  225. this.reviewLists.forEach(item => {
  226. var objItem = arrData.find(res => res.sort === item.sort)
  227. item.id = objItem.id
  228. item.reviewResult = objItem.saveData ? JSON.parse(objItem.saveData).reviewResult : null
  229. item.fqUserName = objItem.fqUserName
  230. item.shenheTime = objItem.shenheTime
  231. item.disabled = !(objItem.dangqian && objItem.isUpdate)
  232. })
  233. console.log(this.reviewLists)
  234. }
  235. },
  236. // deep: true,
  237. immediate: true
  238. }
  239. },
  240. created(){
  241. this.getXnJiesuanE()
  242. },
  243. methods: {
  244. // 获取第一部分设置的项目虚拟结算额并计算数据
  245. getXnJiesuanE(){
  246. // 计算核准虚拟结算额
  247. // this.stepEdit.xnJiesuanE = this.changeData(this.moniData, 'costPrice')
  248. // 项目绩效基础计算
  249. this.computeJixiaoData()
  250. // 计算虚拟结算绩效总额
  251. this.computeJXXishuZonge()
  252. },
  253. // 将试验类型相同的金额相加,用于:核准虚拟结算额和虚拟结算绩效总额
  254. changeData(array, key){
  255. let totalArr = []
  256. array.forEach(element => {
  257. var itemObj = { type: element.type, typeName: element.typeName, price: element[key] }
  258. if(totalArr.length === 0){
  259. totalArr.push(itemObj)
  260. } else {
  261. var index = totalArr.findIndex(res => res.type === element.type)
  262. if(index === -1){
  263. // 原来没有 push
  264. totalArr.push(itemObj)
  265. } else {
  266. // 原来有 相加
  267. totalArr[index].price += itemObj.price
  268. }
  269. }
  270. });
  271. // console.log(totalArr)
  272. return totalArr
  273. },
  274. // 项目绩效基础计算
  275. computeJixiaoData(){
  276. var dataLists = []
  277. for (let i = 0; i < this.stepEdit.xnJiesuanE.length; i++) {
  278. const item = this.stepEdit.xnJiesuanE[i];
  279. const money = item.price * 0.8
  280. if(money > 500000){
  281. // 50万以上
  282. console.log(money+':50万以上')
  283. var arr = [
  284. {
  285. type: item.type,
  286. typeName: item.typeName,
  287. fenduan: item.fenduan,
  288. bili: 0.05,
  289. ticheng: 50000 * 0.05,
  290. yue: 50000
  291. },
  292. {
  293. type: item.type,
  294. typeName: item.typeName,
  295. fenduan: item.fenduan,
  296. bili: 0.04,
  297. ticheng: 50000 * 0.04,
  298. yue: 50000
  299. },
  300. {
  301. type: item.type,
  302. typeName: item.typeName,
  303. fenduan: item.fenduan,
  304. bili: 0.03,
  305. ticheng: 400000 * 0.03,
  306. yue: 400000
  307. },
  308. {
  309. type: item.type,
  310. typeName: item.typeName,
  311. fenduan: item.fenduan,
  312. bili: 0.02,
  313. ticheng: (money - 500000) * 0.02,
  314. yue: money - 500000
  315. },
  316. ]
  317. dataLists.push(...arr)
  318. } else if (money > 100000){
  319. // 10万-50万之间
  320. console.log(money+':10万-50万之间')
  321. var arr = [
  322. {
  323. type: item.type,
  324. typeName: item.typeName,
  325. fenduan: item.fenduan,
  326. bili: 0.05,
  327. ticheng: 50000 * 0.05,
  328. yue: 50000
  329. },
  330. {
  331. type: item.type,
  332. typeName: item.typeName,
  333. fenduan: item.fenduan,
  334. bili: 0.04,
  335. ticheng: 50000 * 0.04,
  336. yue: 50000
  337. },
  338. {
  339. type: item.type,
  340. typeName: item.typeName,
  341. fenduan: item.fenduan,
  342. bili: 0.03,
  343. ticheng: (money - 100000) * 0.03,
  344. yue: money - 100000
  345. },
  346. ]
  347. dataLists.push(...arr)
  348. } else if (money > 50000){
  349. // 5万-10万(包含)之间
  350. console.log(money+':5万-10万(包含)之间')
  351. var arr = [
  352. {
  353. type: item.type,
  354. typeName: item.typeName,
  355. fenduan: item.fenduan,
  356. bili: 0.05,
  357. ticheng: 50000 * 0.05,
  358. yue: 50000
  359. },
  360. {
  361. type: item.type,
  362. typeName: item.typeName,
  363. fenduan: item.fenduan,
  364. bili: 0.04,
  365. ticheng: (money - 50000) * 0.04,
  366. yue: money - 50000
  367. },
  368. ]
  369. dataLists.push(...arr)
  370. } else if (money >= 0){
  371. // 0-5万(包含)之间
  372. console.log(money+':0-5万(包含)之间')
  373. var arr = [
  374. {
  375. type: item.type,
  376. typeName: item.typeName,
  377. fenduan: item.fenduan,
  378. bili: 0.05,
  379. ticheng: money * 0.05,
  380. yue: money
  381. },
  382. ]
  383. dataLists.push(...arr)
  384. }
  385. }
  386. this.stepEdit.jixiaoData = dataLists
  387. },
  388. // 计算虚拟结算绩效总额
  389. computeJXXishuZonge(){
  390. // 将试验类型相同的金额相加
  391. var noHasXishuZonge = this.changeData(this.stepEdit.jixiaoData, 'ticheng')
  392. var total = 0
  393. var arr = noHasXishuZonge.map(item => {
  394. var obj = this.defineXishu.find(res => res.type === item.type)
  395. // 根据试验类型*对应系数
  396. item.price = item.price * obj.xishu
  397. // 计算出总和
  398. total += item.price
  399. return item
  400. })
  401. this.stepEdit.xnJixiaoZongeArr = arr
  402. console.log(total)
  403. this.stepEdit.xnJixiaoZonge = total
  404. },
  405. // 提交
  406. submitSCReview(){
  407. var saveData = {
  408. runFlowPathStep: this.stepParameter.id,
  409. saveData: JSON.stringify(this.stepEdit),
  410. }
  411. console.log(saveData)
  412. this.$emit('save', saveData)
  413. },
  414. submitReview(item){
  415. if(item.sort === '11'){
  416. var saveData = {
  417. runFlowPathStep: item.id,
  418. saveData: JSON.stringify({reviewResult: `考核系数:100%;(对应哪儿个) 实际积分: ${(this.stepEdit.xnJixiaoZonge * this.stepEdit.manyidu)/100} `}),
  419. }
  420. } else {
  421. var saveData = {
  422. runFlowPathStep: item.id,
  423. saveData: JSON.stringify({reviewResult: item.reviewResult}),
  424. }
  425. }
  426. console.log(saveData)
  427. this.$emit('save', saveData)
  428. }
  429. },
  430. }
  431. </script>
  432. <style scoped>
  433. @import '~@assets/less/common.less';
  434. table * {
  435. box-sizing: border-box;
  436. font-size: 14px;
  437. }
  438. table {
  439. border: 1px solid rgb(30, 53, 65);
  440. width: 100%;
  441. table-layout:fixed;
  442. }
  443. td {
  444. text-align: center;
  445. border: 1px solid rgb(30, 53, 65);
  446. }
  447. tr {
  448. height: 50px;
  449. }
  450. .main-table {
  451. background-color: #DBEEF3;
  452. }
  453. .title {
  454. background-color: #fff;
  455. font-weight: bold;
  456. }
  457. .addRow {
  458. width: 60px;
  459. height: 24px;
  460. background-color: #fff;
  461. border-radius: 4px;
  462. text-align: center;
  463. line-height: 24px;
  464. font-size: 12px;
  465. margin-left: 20px;
  466. cursor: pointer;
  467. }
  468. .btn {
  469. display: inline-block;
  470. padding: 2px 10px;
  471. font-size: 13px;
  472. border: 1px solid rgb(3, 188, 244);
  473. color: rgb(8, 187, 241);
  474. border-radius: 4px;
  475. cursor: pointer;
  476. position: absolute;
  477. right: 3%;
  478. }
  479. .delBtn {
  480. padding: 3px 10px;
  481. text-align: center;
  482. font-size: 12px;
  483. }
  484. input {
  485. padding: 0 20px;
  486. height: 50px;
  487. outline: none;
  488. border: none;
  489. background: transparent;
  490. }
  491. .head {
  492. height: 35px;
  493. background-color: #FFFF00;
  494. text-align: center;
  495. line-height: 35px;
  496. font-weight: bold;
  497. font-size: 18px;
  498. border: 1px solid rgb(30, 53, 65);
  499. }
  500. </style>