radio.vue 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <template>
  2. <div>
  3. <el-form-item label="默认值">
  4. <el-input v-model="data.valueDefault"
  5. placeholder="默认值"></el-input>
  6. </el-form-item>
  7. <el-form-item label="字典配置"><br>
  8. <el-tabs v-model="data.dicOption"
  9. stretch
  10. @tab-click="handleTabClick">
  11. <el-tab-pane label="静态数据"
  12. name="static">
  13. <draggable tag="ul"
  14. :list="data.dicData"
  15. :group="{ name: 'dic' }"
  16. ghost-class="ghost"
  17. handle=".drag-item">
  18. <li v-for="(item, index) in data.dicData"
  19. :key="index">
  20. <i class="drag-item el-icon-s-operation"
  21. style="font-size: 16px; margin: 0 5px; cursor: move;"></i>
  22. <el-input style="margin-right: 5px;"
  23. size="mini"
  24. v-model="item.label"
  25. placeholder="label"></el-input>
  26. <el-input size="mini"
  27. v-model="item.value"
  28. placeholder="value"></el-input>
  29. <el-button @click="handleRemoveFields(index)"
  30. circle
  31. plain
  32. type="danger"
  33. size="mini"
  34. icon="el-icon-minus"
  35. style="padding: 4px;margin-left: 5px;"></el-button>
  36. </li>
  37. </draggable>
  38. <div style="margin-left: 22px;">
  39. <el-button type="text"
  40. @click="handleAddFields">添加列
  41. </el-button>
  42. </div>
  43. </el-tab-pane>
  44. <el-tab-pane label="远端数据"
  45. name="remote">
  46. 网址
  47. <el-input v-model="data.dicUrl"
  48. placeholder="远端数据字典网址"></el-input>
  49. 请求方法
  50. <el-select v-model="data.dicMethod"
  51. placeholder="请求方法"
  52. style="width: 100%;">
  53. <el-option label="POST"
  54. value="post"></el-option>
  55. <el-option label="GET"
  56. value="get"></el-option>
  57. </el-select>
  58. <p v-if="data.dicMethod == 'post'">
  59. 请求参数
  60. <avue-dynamic v-model="data.dicQuery"
  61. :children="option"></avue-dynamic>
  62. </p>
  63. </el-tab-pane>
  64. </el-tabs>
  65. </el-form-item>
  66. <el-form-item label="边框">
  67. <el-switch v-model="data.border"></el-switch>
  68. </el-form-item>
  69. <el-form-item label="尺寸"
  70. v-if="data.border">
  71. <el-radio-group v-model="data.size"
  72. size="mini">
  73. <el-radio-button label="medium">正常</el-radio-button>
  74. <el-radio-button label="small">小</el-radio-button>
  75. <el-radio-button label="mini">超小</el-radio-button>
  76. </el-radio-group>
  77. </el-form-item>
  78. <el-form-item label="是否禁用">
  79. <el-switch v-model="data.disabled"></el-switch>
  80. </el-form-item>
  81. <el-form-item label="是否可见">
  82. <el-switch v-model="data.display"></el-switch>
  83. </el-form-item>
  84. <el-form-item label="是否必填">
  85. <el-switch v-model="data.required"></el-switch>
  86. </el-form-item>
  87. </div>
  88. </template>
  89. <script>
  90. import Draggable from 'vuedraggable'
  91. export default {
  92. name: "config-radio",
  93. props: ['data'],
  94. components: { Draggable },
  95. data () {
  96. return {
  97. validator: {
  98. type: null,
  99. required: null,
  100. pattern: null,
  101. length: null
  102. },
  103. option: {
  104. column: [{
  105. type: 'input',
  106. prop: 'key',
  107. label: 'key'
  108. }, {
  109. type: 'input',
  110. prop: 'value',
  111. label: 'value'
  112. }]
  113. },
  114. }
  115. },
  116. methods: {
  117. generateRule () {
  118. const rules = [];
  119. Object.keys(this.validator).forEach(key => {
  120. if (this.validator[key]) rules.push(this.validator[key])
  121. })
  122. this.data.rules = rules
  123. },
  124. handleRemoveFields (index) {
  125. this.data.dicData.splice(index, 1)
  126. },
  127. handleAddFields () {
  128. const i = Math.ceil(Math.random() * 99999)
  129. this.data.dicData.push({ label: `字段${i}`, value: `col_${i}` })
  130. },
  131. handleTabClick ({ name }) {
  132. if (name == 'remote' && !this.data.dicQuery) this.data.dicQuery = []
  133. }
  134. },
  135. watch: {
  136. 'data.required': function (val) {
  137. if (val) this.validator.required = { required: true, message: `请选择${this.data.label}` }
  138. else this.validator.required = null
  139. this.generateRule()
  140. }
  141. }
  142. }
  143. </script>