scoreDialog.vue 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <template>
  2. <el-dialog v-model="visible" title="政策考核评分" width="680" @closed="$emit('closed')">
  3. <el-form ref="formRef" :model="form" :rules="rules" :disabled="disabled" label-width="110px">
  4. <el-row>
  5. <el-col :span="12">
  6. <el-form-item label="落地金额">
  7. <el-input-number v-model="form.landAmount" readonly :precision="2" :controls="false"></el-input-number>
  8. </el-form-item>
  9. </el-col>
  10. <el-col :span="12">
  11. <el-form-item label="考核基数">
  12. <el-input-number v-model="form.rewardRadix" readonly :controls="false"></el-input-number>
  13. </el-form-item>
  14. </el-col>
  15. <el-col :push="2" :span="20">
  16. <el-form-item label="实施难易程度" prop="implementScore">
  17. <el-input-number v-model="form.implementScore" :min="0" :max="1" :step="0.1" :precision="2" :controls="false" placeholder="实施难易程度" @change="calcWeight"></el-input-number>
  18. </el-form-item>
  19. </el-col>
  20. <el-col :push="2" :span="20">
  21. <el-form-item label="复制推广潜力" prop="promotionScore">
  22. <el-input-number v-model="form.promotionScore" :min="0" :max="1" :step="0.1" :precision="2" :controls="false" placeholder="复制推广潜力" @change="calcWeight"></el-input-number>
  23. </el-form-item>
  24. </el-col>
  25. <el-col :push="2" :span="20">
  26. <el-form-item label="政策争取效果" prop="striveScore">
  27. <el-input-number v-model="form.striveScore" :min="0" :max="1" :step="0.1" :precision="2" :controls="false" placeholder="政策争取效果" @change="calcWeight"></el-input-number>
  28. </el-form-item>
  29. </el-col>
  30. <el-col :push="2" :span="20">
  31. <el-form-item label="奖励标准" prop="rewardScore">
  32. <el-input-number v-model="form.rewardScore" readonly :controls="false"></el-input-number>
  33. </el-form-item>
  34. </el-col>
  35. </el-row>
  36. </el-form>
  37. <template #footer>
  38. <el-button type="primary" @click="submit">确 定</el-button>
  39. </template>
  40. </el-dialog>
  41. </template>
  42. <script>
  43. import API from "@/api/policy/strive";
  44. export default {
  45. emits: ["success", "closed"],
  46. props: {
  47. disabled: { type: Boolean, default: false }
  48. },
  49. data() {
  50. return {
  51. visible: false,
  52. form: {
  53. id: null,
  54. landAmount: null,
  55. rewardRadix: null,
  56. implementScore: null,
  57. promotionScore: null,
  58. striveScore: null,
  59. rewardScore: null
  60. },
  61. rules: {
  62. implementScore: [{ required: true, message: "请输入分值" }],
  63. promotionScore: [{ required: true, message: "请输入分值" }],
  64. striveScore: [{ required: true, message: "请输入分值" }]
  65. }
  66. }
  67. },
  68. methods: {
  69. open() {
  70. this.visible = true;
  71. return this;
  72. },
  73. setData(data) {
  74. for (const key in this.form) {
  75. this.form[key] = data[key] || null;
  76. }
  77. this.calcWeight();
  78. },
  79. calcWeight() {
  80. API.calculate({
  81. rewardRadix: !!this.form.rewardRadix && this.form.rewardRadix || 0,
  82. implementScore: !!this.form.implementScore && this.form.implementScore || 0,
  83. promotionScore: !!this.form.promotionScore && this.form.promotionScore || 0,
  84. striveScore: !!this.form.striveScore && this.form.striveScore || 0
  85. }).then(res => {
  86. if (res.code === 200) this.form.rewardScore = res.data != 0 && res.data || null;
  87. else this.form.rewardScore = null;
  88. }).catch(() => this.form.rewardScore = null);
  89. },
  90. // 表单提交方法
  91. submit() {
  92. this.$refs.formRef.validate(valid => {
  93. if (valid) {
  94. API.updateById({ ...this.form }).then(res => {
  95. ElMessage.success("操作成功");
  96. this.visible = false;
  97. this.$emit("success");
  98. });
  99. } else {
  100. return false;
  101. }
  102. });
  103. }
  104. }
  105. }
  106. </script>
  107. <style lang="scss" scoped>
  108. .el-input-number {
  109. width: 100%;
  110. :deep(.el-input) .el-input__wrapper {
  111. padding: 1px 11px;
  112. .el-input__inner {
  113. text-align: unset;
  114. }
  115. }
  116. }
  117. </style>