index.vue 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. <template>
  2. <div>
  3. <!-- 初始版本自动化代码工具 -->
  4. <el-form ref="autoCodeForm" :rules="rules" :model="form" label-width="120px" :inline="true">
  5. <el-form-item label="Struct名称" prop="structName">
  6. <el-input v-model="form.structName" placeholder="首字母自动转换大写"></el-input>
  7. </el-form-item>
  8. <el-form-item label="Struct简称" prop="abbreviation">
  9. <el-input v-model="form.abbreviation" placeholder="简称会作为入参对象名和路由group"></el-input>
  10. </el-form-item>
  11. <el-form-item label="Struct中文名称" prop="description">
  12. <el-input v-model="form.description" placeholder="中文描述作为自动api描述"></el-input>
  13. </el-form-item>
  14. <el-form-item label="文件名称" prop="packageName">
  15. <el-input v-model="form.packageName"></el-input>
  16. </el-form-item>
  17. <el-form-item label="自动创建api">
  18. <el-checkbox v-model="form.autoCreateApiToSql"></el-checkbox>
  19. </el-form-item>
  20. </el-form>
  21. <!-- 组件列表 -->
  22. <div class="button-box clearflex">
  23. <el-button @click="editAndAddField()" type="primary">新增Field</el-button>
  24. </div>
  25. <el-table :data="form.fields" border stripe>
  26. <el-table-column type="index" label="序列" width="100">
  27. </el-table-column>
  28. <el-table-column prop="fieldName" label="Field名">
  29. </el-table-column>
  30. <el-table-column prop="fieldDesc" label="中文名">
  31. </el-table-column>
  32. <el-table-column prop="fieldJson" label="FieldJson">
  33. </el-table-column>
  34. <el-table-column prop="fieldType" label="Field数据类型" width="130">
  35. </el-table-column>
  36. <el-table-column prop="columnName" label="数据库字段" width="130">
  37. </el-table-column>
  38. <el-table-column prop="comment" label="数据库字段描述" width="130">
  39. </el-table-column>
  40. <el-table-column prop="fieldSearchType" label="搜索条件" width="130">
  41. </el-table-column>
  42. <el-table-column label="操作" width="300">
  43. <template slot-scope="scope">
  44. <el-button size="mini" type="primary" icon="el-icon-edit" @click="editAndAddField(scope.row)">编辑</el-button>
  45. <el-button size="mini" type="text" :disabled="scope.$index == 0" @click="moveUpField(scope.$index)">上移</el-button>
  46. <el-button size="mini" type="text" :disabled="(scope.$index + 1) == form.fields.length" @click="moveDownField(scope.$index)">下移</el-button>
  47. <el-popover placement="top" v-model="scope.row.visible">
  48. <p>确定删除吗?</p>
  49. <div style="text-align: right; margin: 0">
  50. <el-button size="mini" type="text" @click="scope.row.visible = false">取消</el-button>
  51. <el-button type="primary" size="mini" @click="deleteField(scope.$index)">确定</el-button>
  52. </div>
  53. <el-button size="mini" type="danger" icon="el-icon-delete" slot="reference">删除</el-button>
  54. </el-popover>
  55. </template>
  56. </el-table-column>
  57. </el-table>
  58. <!-- 组件列表 -->
  59. <div class="button-box clearflex">
  60. <el-button @click="enterForm" type="primary">生成代码包</el-button>
  61. </div>
  62. <!-- 组件弹窗 -->
  63. <el-dialog title="组件内容" :visible.sync="dialogFlag">
  64. <FieldDialog :dialogMiddle="dialogMiddle" ref="fieldDialog" />
  65. <div slot="footer" class="dialog-footer">
  66. <el-button @click="closeDialog">取 消</el-button>
  67. <el-button type="primary" @click="enterDialog">确 定</el-button>
  68. </div>
  69. </el-dialog>
  70. </div>
  71. </template>
  72. <script>
  73. const fieldTemplate = {
  74. fieldName: '',
  75. fieldDesc: '',
  76. fieldType: '',
  77. fieldJson: '',
  78. columnName: '',
  79. comment:'',
  80. fieldSearchType:''
  81. }
  82. import FieldDialog from '@/view/systemTools/autoCode/component/fieldDialog.vue'
  83. import { toUpperCase } from '@/utils/stringFun.js'
  84. import { createTemp } from '@/api/autoCode.js'
  85. export default {
  86. name: 'autoCode',
  87. data() {
  88. return {
  89. addFlag: '',
  90. form: {
  91. structName: '',
  92. packageName: '',
  93. abbreviation: '',
  94. description:'',
  95. autoCreateApiToSql: false,
  96. fields: [],
  97. },
  98. rules: {
  99. structName: [{ required: true, message: '请输入结构体名称', trigger: 'blur' }],
  100. abbreviation: [{ required: true, message: '请输入结构体简称', trigger: 'blur' }],
  101. description: [{ required: true, message: '请输入结构体描述', trigger: 'blur' }],
  102. packageName: [{ required: true, message: '文件名称:sys_xxxx_xxxx', trigger: 'blur' }],
  103. },
  104. dialogMiddle: {},
  105. bk: {},
  106. dialogFlag: false,
  107. }
  108. },
  109. components: {
  110. FieldDialog,
  111. },
  112. methods: {
  113. editAndAddField(item) {
  114. this.dialogFlag = true
  115. if (item) {
  116. this.addFlag = 'edit'
  117. this.bk = JSON.parse(JSON.stringify(item))
  118. this.dialogMiddle = item
  119. } else {
  120. this.addFlag = 'add'
  121. this.dialogMiddle = JSON.parse(JSON.stringify(fieldTemplate))
  122. }
  123. },
  124. moveUpField(index) {
  125. if (index == 0) {
  126. return
  127. }
  128. const oldUpField = this.form.fields[index - 1]
  129. this.form.fields.splice(index - 1, 1)
  130. this.form.fields.splice(index, 0, oldUpField)
  131. },
  132. moveDownField(index) {
  133. const fCount = this.form.fields.length
  134. if (index == fCount - 1) {
  135. return
  136. }
  137. const oldDownField = this.form.fields[index + 1]
  138. this.form.fields.splice(index + 1, 1)
  139. this.form.fields.splice(index, 0, oldDownField)
  140. },
  141. enterDialog() {
  142. this.$refs.fieldDialog.$refs.fieldDialogFrom.validate((valid) => {
  143. if (valid) {
  144. this.dialogMiddle.fieldName = toUpperCase(this.dialogMiddle.fieldName)
  145. if (this.addFlag == 'add') {
  146. this.form.fields.push(this.dialogMiddle)
  147. }
  148. this.dialogFlag = false
  149. } else {
  150. return false
  151. }
  152. })
  153. },
  154. closeDialog() {
  155. if (this.addFlag == 'edit') {
  156. this.dialogMiddle = this.bk
  157. }
  158. this.dialogFlag = false
  159. },
  160. deleteField(index) {
  161. this.form.fields.splice(index, 1)
  162. },
  163. async enterForm() {
  164. if (this.form.fields.length <= 0) {
  165. this.$message({
  166. type: 'error',
  167. message: '请填写至少一个field',
  168. })
  169. return false
  170. }
  171. if(this.form.fields.some(item=>item.fieldName == this.form.structName)){
  172. this.$message({
  173. type: 'error',
  174. message: '存在与结构体同名的字段',
  175. })
  176. return false
  177. }
  178. this.$refs.autoCodeForm.validate(async (valid) => {
  179. if (valid) {
  180. this.form.structName = toUpperCase(this.form.structName)
  181. if (this.form.structName == this.form.abbreviation) {
  182. this.$message({
  183. type: 'error',
  184. message: 'structName和struct简称不能相同',
  185. })
  186. return false
  187. }
  188. const data = await createTemp(this.form)
  189. const blob = new Blob([data])
  190. const fileName = 'ginvueadmin.zip'
  191. if ('download' in document.createElement('a')) {
  192. // 不是IE浏览器
  193. let url = window.URL.createObjectURL(blob)
  194. let link = document.createElement('a')
  195. link.style.display = 'none'
  196. link.href = url
  197. link.setAttribute('download', fileName)
  198. document.body.appendChild(link)
  199. link.click()
  200. document.body.removeChild(link) // 下载完成移除元素
  201. window.URL.revokeObjectURL(url) // 释放掉blob对象
  202. } else {
  203. // IE 10+
  204. window.navigator.msSaveBlob(blob, fileName)
  205. }
  206. } else {
  207. return false
  208. }
  209. })
  210. },
  211. },
  212. }
  213. </script>
  214. <style scope lang="scss">
  215. .button-box {
  216. padding: 10px 20px;
  217. .el-button {
  218. float: right;
  219. }
  220. }
  221. </style>