newAdd.vue 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. <script setup lang="ts">
  2. defineOptions({
  3. name: "evaluateNewAdd"
  4. });
  5. import { ref, reactive } from "vue";
  6. import { useRouter } from "vue-router";
  7. const router = useRouter();
  8. const active = ref(0);
  9. const handleSelect = index => {
  10. // console.log(index);
  11. active.value = index;
  12. };
  13. const tepName = ref();
  14. const tepNameForm = reactive({
  15. name: "张三"
  16. });
  17. const backChange = () => {
  18. router.back();
  19. };
  20. const tableData = ref([
  21. {
  22. date: "2016-05-01",
  23. name: "Tom",
  24. state: "California",
  25. city: "Los Angeles",
  26. address: "No. 189, Grove St, Los Angeles",
  27. zip: "CA 90036"
  28. },
  29. {
  30. date: "2016-05-02",
  31. name: "Tom",
  32. state: "California",
  33. city: "Los Angeles",
  34. address: "No. 189, Grove St, Los Angeles",
  35. zip: "CA 90036"
  36. },
  37. {
  38. date: "2016-05-03",
  39. name: "Tom",
  40. state: "California",
  41. city: "Los Angeles",
  42. address: "No. 189, Grove St, Los Angeles",
  43. zip: "CA 90036"
  44. },
  45. {
  46. date: "2016-05-03",
  47. name: "Tom",
  48. state: "California",
  49. city: "Los Angeles",
  50. address: "No. 189, Grove St, Los Angeles",
  51. zip: "CA 90036"
  52. },
  53. {
  54. date: "2016-05-03",
  55. name: "Tom",
  56. state: "California",
  57. city: "Los Angeles",
  58. address: "No. 189, Grove St, Los Angeles",
  59. zip: "CA 90036"
  60. },
  61. {
  62. date: "2016-05-03",
  63. name: "Tom",
  64. state: "California",
  65. city: "Los Angeles",
  66. address: "No. 189, Grove St, Los Angeles",
  67. zip: "CA 90036"
  68. },
  69. {
  70. date: "2016-05-03",
  71. name: "Tom",
  72. state: "California",
  73. city: "Los Angeles",
  74. address: "No. 189, Grove St, Los Angeles",
  75. zip: "CA 90036"
  76. }
  77. ]);
  78. const save = () => {
  79. if (active.value++ > 2) active.value = 0;
  80. };
  81. const deleteRow = row => {
  82. console.log(row);
  83. };
  84. </script>
  85. <template>
  86. <div class="w-[100%]">
  87. <div class="w-[100%] flex justify-evenly">
  88. <div class="left-box">
  89. <el-text class="cursor-pointer" @click="backChange"
  90. ><el-icon><ArrowLeft /></el-icon>返回</el-text
  91. >
  92. </div>
  93. <div class="center-box">
  94. <el-menu
  95. default-active="1"
  96. class="el-menu-demo flex justify-evenly"
  97. mode="horizontal"
  98. @select="handleSelect"
  99. >
  100. <el-menu-item index="1">基础信息</el-menu-item>
  101. <el-menu-item index="2">考核指标</el-menu-item>
  102. <el-menu-item index="3">考核流程</el-menu-item>
  103. </el-menu>
  104. <!-- <el-steps
  105. style="max-width: 600px"
  106. :active="active"
  107. finish-status="success"
  108. class="m-auto "
  109. >
  110. <el-step title="基础信息" />
  111. <el-step title="考核指标" />
  112. <el-step title="考核流程" />
  113. </el-steps> -->
  114. </div>
  115. <div class="right-box">
  116. <el-button type="primary" class="mr-2" @click="save">保存</el-button>
  117. </div>
  118. </div>
  119. <div class="mt-2">
  120. <div v-if="active == 1" class="w-[40%] m-auto mt-10">
  121. <el-form
  122. :model="tepNameForm"
  123. label-width="auto"
  124. style="max-width: 600px"
  125. >
  126. <el-form-item
  127. label="模板名称"
  128. prop="name"
  129. :rules="[
  130. {
  131. required: true,
  132. message: '请输入模板名称',
  133. trigger: 'blur'
  134. }
  135. ]"
  136. >
  137. <el-input v-model="tepName" placeholder="最多输入100字" />
  138. </el-form-item>
  139. </el-form>
  140. </div>
  141. <div v-if="active == 2" class="w-[90%] m-auto mt-10">
  142. <div class="relative h-10">
  143. <el-button class="float-right" type="primary" plain
  144. >创建考核维度</el-button
  145. >
  146. </div>
  147. <el-card class="mb-3">
  148. <template #header>
  149. <div class="card-header">
  150. <span>工作量(30%)</span>
  151. <div class="float-right mr-7">
  152. <el-icon class="mr-3"><EditPen /></el-icon>
  153. <el-icon><Delete class="text-red-500" /></el-icon>
  154. </div>
  155. </div>
  156. </template>
  157. <el-table :data="tableData" style="width: 100%" max-height="250">
  158. <el-table-column fixed prop="date" label="指标名称" width="150" />
  159. <el-table-column prop="name" label="指标说明" width="120" />
  160. <el-table-column prop="state" label="评价标准" width="300" />
  161. <el-table-column prop="state" label="数据来源" width="120" />
  162. <el-table-column prop="city" label="权重" width="120" />
  163. <el-table-column prop="name" label="分值" width="120" />
  164. <el-table-column prop="zip" label="目标值" width="120" />
  165. <el-table-column fixed="right" label="操作">
  166. <template #default="{ row }">
  167. <el-icon class="mr-3"><Setting /></el-icon>
  168. <el-icon @click="deleteRow(row)"
  169. ><Delete class="text-red-500"
  170. /></el-icon>
  171. </template>
  172. </el-table-column>
  173. </el-table>
  174. </el-card>
  175. </div>
  176. </div>
  177. </div>
  178. </template>
  179. <style lang="scss" scoped>
  180. .left-box {
  181. display: flex;
  182. flex: 0 0 5%;
  183. align-items: center;
  184. margin: auto;
  185. text-align: center;
  186. // justify-content: center;
  187. }
  188. .center-box {
  189. flex: 0 0 70%;
  190. }
  191. .right-box {
  192. display: flex;
  193. flex: 0 0 5%;
  194. align-items: center;
  195. justify-content: center;
  196. margin: auto;
  197. }
  198. </style>