column.vue 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <template>
  2. <el-drawer :visible.sync="visible" size="80%" append-to-body>
  3. <el-table :data="list" border>
  4. <el-table-column align="center" width="60">
  5. <template #header>
  6. <el-button icon="el-icon-plus" type="primary" circle size="mini" @click="list.push({})"></el-button>
  7. </template>
  8. <template #default="{ $index }">
  9. <el-button
  10. icon="el-icon-minus"
  11. type="danger"
  12. circle
  13. size="mini"
  14. @click="list.splice($index, 1)"
  15. ></el-button>
  16. </template>
  17. </el-table-column>
  18. <el-table-column label="字段名" prop="label" align="center">
  19. <template #default="{ row }">
  20. <el-input v-model="row.label" placeholder="请输入 字段名"></el-input>
  21. </template>
  22. </el-table-column>
  23. <el-table-column label="Prop" prop="prop" align="center">
  24. <template #default="{ row }">
  25. <el-input v-model="row.prop" placeholder="请输入 prop"></el-input>
  26. </template>
  27. </el-table-column>
  28. <el-table-column label="类型" prop="type" align="center">
  29. <template #default="{ row }">
  30. <el-select style="width: 100%;" v-model="row.type" placeholder="请选择 类型" filterable>
  31. <el-option
  32. v-for="item in fields"
  33. :key="item.value"
  34. :label="item.value"
  35. :value="item.value"
  36. ></el-option>
  37. </el-select>
  38. </template>
  39. </el-table-column>
  40. <el-table-column label="搜索" prop="search" align="center">
  41. <template #default="{ row }">
  42. <el-switch v-model="row.search"></el-switch>
  43. </template>
  44. </el-table-column>
  45. <el-table-column label="操作" align="center">
  46. <template #default="{ row }">
  47. <template v-if="['select', 'cascader', 'tree', 'radio', 'checkbox'].includes(row.type)">
  48. <el-button type="text" @click="handleDic(row)">字典配置</el-button>
  49. </template>
  50. </template>
  51. </el-table-column>
  52. </el-table>
  53. <span class="afd-drawer-foot">
  54. <el-button @click="handleSubmit" type="primary">确定</el-button>
  55. <el-button @click="visible = false">取消</el-button>
  56. </span>
  57. </el-drawer>
  58. </template>
  59. <script>
  60. import fields from './field.js'
  61. export default {
  62. name: 'column',
  63. props: {
  64. column: []
  65. },
  66. emits: ['submit'],
  67. watch: {
  68. column: {
  69. handler(val) {
  70. this.list = val
  71. },
  72. deep: true,
  73. immediate: true
  74. }
  75. },
  76. data() {
  77. return {
  78. fields,
  79. visible: false,
  80. list: []
  81. }
  82. },
  83. methods: {
  84. handleSubmit() {
  85. this.$emit('submit', this.deepClone(this.list))
  86. this.visible = false
  87. },
  88. handleDic(row) {
  89. console.log(row)
  90. this.$message.error('暂未实现')
  91. }
  92. }
  93. }
  94. </script>