form.vue.vm 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. <template>
  2. <div class="app-container">
  3. <!-- 对话框(添加 / 修改) -->
  4. <el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="45%" v-dialogDrag append-to-body>
  5. <el-form ref="formRef" :model="formData" :rules="formRules" v-loading="formLoading" label-width="100px">
  6. #foreach($column in $columns)
  7. #if ($column.createOperation || $column.updateOperation)
  8. #set ($dictType = $column.dictType)
  9. #set ($javaField = $column.javaField)
  10. #set ($AttrName = $column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)})
  11. #set ($comment = $column.columnComment)
  12. #if ( $table.templateType == 2 && $column.id == $treeParentColumn.id )
  13. <el-form-item label="${comment}" prop="${javaField}">
  14. <TreeSelect
  15. v-model="formData.${javaField}"
  16. :options="${classNameVar}Tree"
  17. :normalizer="normalizer"
  18. placeholder="请选择${comment}"
  19. />
  20. </el-form-item>
  21. #elseif ($column.htmlType == "input" && !$column.primaryKey)## 忽略主键,不用在表单里
  22. <el-form-item label="${comment}" prop="${javaField}">
  23. <el-input v-model="formData.${javaField}" placeholder="请输入${comment}" />
  24. </el-form-item>
  25. #elseif($column.htmlType == "imageUpload")## 图片上传
  26. #set ($hasImageUploadColumn = true)
  27. <el-form-item label="${comment}">
  28. <ImageUpload v-model="formData.${javaField}"/>
  29. </el-form-item>
  30. #elseif($column.htmlType == "fileUpload")## 文件上传
  31. #set ($hasFileUploadColumn = true)
  32. <el-form-item label="${comment}">
  33. <FileUpload v-model="formData.${javaField}"/>
  34. </el-form-item>
  35. #elseif($column.htmlType == "editor")## 文本编辑器
  36. #set ($hasEditorColumn = true)
  37. <el-form-item label="${comment}">
  38. <Editor v-model="formData.${javaField}" :min-height="192"/>
  39. </el-form-item>
  40. #elseif($column.htmlType == "select")## 下拉框
  41. <el-form-item label="${comment}" prop="${javaField}">
  42. <el-select v-model="formData.${javaField}" placeholder="请选择${comment}">
  43. #if ("" != $dictType)## 有数据字典
  44. <el-option v-for="dict in this.getDictDatas(DICT_TYPE.$dictType.toUpperCase())"
  45. :key="dict.value" :label="dict.label" #if ($column.javaType == "Integer" || $column.javaType == "Long"):value="parseInt(dict.value)"#else:value="dict.value"#end />
  46. #else##没数据字典
  47. <el-option label="请选择字典生成" value="" />
  48. #end
  49. </el-select>
  50. </el-form-item>
  51. #elseif($column.htmlType == "checkbox")## 多选框
  52. <el-form-item label="${comment}" prop="${javaField}">
  53. <el-checkbox-group v-model="formData.${javaField}">
  54. #if ("" != $dictType)## 有数据字典
  55. <el-checkbox v-for="dict in this.getDictDatas(DICT_TYPE.$dictType.toUpperCase())"
  56. :key="dict.value" #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"#else:label="dict.value"#end>{{dict.label}}</el-checkbox>
  57. #else##没数据字典
  58. <el-checkbox>请选择字典生成</el-checkbox>
  59. #end
  60. </el-checkbox-group>
  61. </el-form-item>
  62. #elseif($column.htmlType == "radio")## 单选框
  63. <el-form-item label="${comment}" prop="${javaField}">
  64. <el-radio-group v-model="formData.${javaField}">
  65. #if ("" != $dictType)## 有数据字典
  66. <el-radio v-for="dict in this.getDictDatas(DICT_TYPE.$dictType.toUpperCase())"
  67. :key="dict.value" #if($column.javaType == "Integer" || $column.javaType == "Long"):label="parseInt(dict.value)"
  68. #else:label="dict.value"#end>{{dict.label}}</el-radio>
  69. #else##没数据字典
  70. <el-radio label="1">请选择字典生成</el-radio>
  71. #end
  72. </el-radio-group>
  73. </el-form-item>
  74. #elseif($column.htmlType == "datetime")## 时间框
  75. <el-form-item label="${comment}" prop="${javaField}">
  76. <el-date-picker clearable v-model="formData.${javaField}" type="date" value-format="timestamp" placeholder="选择${comment}" />
  77. </el-form-item>
  78. #elseif($column.htmlType == "textarea")## 文本框
  79. <el-form-item label="${comment}" prop="${javaField}">
  80. <el-input v-model="formData.${javaField}" type="textarea" placeholder="请输入内容" />
  81. </el-form-item>
  82. #end
  83. #end
  84. #end
  85. </el-form>
  86. ## 特殊:主子表专属逻辑
  87. #if ( $table.templateType == 10 || $table.templateType == 12 )
  88. <!-- 子表的表单 -->
  89. <el-tabs v-model="subTabsName">
  90. #foreach ($subTable in $subTables)
  91. #set ($index = $foreach.count - 1)
  92. #set ($subClassNameVar = $subClassNameVars.get($index))
  93. #set ($subSimpleClassName = $subSimpleClassNames.get($index))
  94. #set ($subJoinColumn_strikeCase = $subJoinColumn_strikeCases.get($index))
  95. <el-tab-pane label="${subTable.classComment}" name="$subClassNameVar">
  96. <${subSimpleClassName}Form ref="${subClassNameVar}FormRef" :${subJoinColumn_strikeCase}="formData.id" />
  97. </el-tab-pane>
  98. #end
  99. </el-tabs>
  100. #end
  101. <div slot="footer" class="dialog-footer">
  102. <el-button type="primary" @click="submitForm" :disabled="formLoading">确 定</el-button>
  103. <el-button @click="dialogVisible = false">取 消</el-button>
  104. </div>
  105. </el-dialog>
  106. </div>
  107. </template>
  108. <script>
  109. import * as ${simpleClassName}Api from '@/api/${table.moduleName}/${table.businessName}'
  110. #if ($hasImageUploadColumn)
  111. import ImageUpload from '@/components/ImageUpload';
  112. #end
  113. #if ($hasFileUploadColumn)
  114. import FileUpload from '@/components/FileUpload';
  115. #end
  116. #if ($hasEditorColumn)
  117. import Editor from '@/components/Editor';
  118. #end
  119. ## 特殊:树表专属逻辑
  120. #if ( $table.templateType == 2 )
  121. import TreeSelect from "@riophae/vue-treeselect";
  122. import "@riophae/vue-treeselect/dist/vue-treeselect.css";
  123. #end
  124. ## 特殊:主子表专属逻辑
  125. #if ( $table.templateType == 10 || $table.templateType == 12 )
  126. #foreach ($subSimpleClassName in $subSimpleClassNames)
  127. import ${subSimpleClassName}Form from './components/${subSimpleClassName}Form.vue'
  128. #end
  129. #end
  130. export default {
  131. name: "${simpleClassName}Form",
  132. components: {
  133. #if ($hasImageUploadColumn)
  134. ImageUpload,
  135. #end
  136. #if ($hasFileUploadColumn)
  137. FileUpload,
  138. #end
  139. #if ($hasEditorColumn)
  140. Editor,
  141. #end
  142. ## 特殊:树表专属逻辑
  143. #if ( $table.templateType == 2 )
  144. TreeSelect,
  145. #end
  146. ## 特殊:主子表专属逻辑
  147. #if ( $table.templateType == 10 || $table.templateType == 12 )
  148. #foreach ($subSimpleClassName in $subSimpleClassNames)
  149. ${subSimpleClassName}Form,
  150. #end
  151. #end
  152. },
  153. data() {
  154. return {
  155. // 弹出层标题
  156. dialogTitle: "",
  157. // 是否显示弹出层
  158. dialogVisible: false,
  159. // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
  160. formLoading: false,
  161. // 表单参数
  162. formData: {
  163. #foreach ($column in $columns)
  164. #if ($column.createOperation || $column.updateOperation)
  165. #if ($column.htmlType == "checkbox")
  166. $column.javaField: [],
  167. #else
  168. $column.javaField: undefined,
  169. #end
  170. #end
  171. #end
  172. },
  173. // 表单校验
  174. formRules: {
  175. #foreach ($column in $columns)
  176. #if (($column.createOperation || $column.updateOperation) && !$column.nullable && !${column.primaryKey})## 创建或者更新操作 && 要求非空 && 非主键
  177. #set($comment=$column.columnComment)
  178. $column.javaField: [{ required: true, message: '${comment}不能为空', trigger: #if($column.htmlType == 'select')'change'#else'blur'#end }],
  179. #end
  180. #end
  181. },
  182. ## 特殊:树表专属逻辑
  183. #if ( $table.templateType == 2 )
  184. ${classNameVar}Tree: [], // 树形结构
  185. #end
  186. ## 特殊:主子表专属逻辑
  187. #if ( $table.templateType == 10 || $table.templateType == 12 )
  188. #if ( $subTables && $subTables.size() > 0 )
  189. /** 子表的表单 */
  190. subTabsName: '$subClassNameVars.get(0)'
  191. #end
  192. #end
  193. };
  194. },
  195. methods: {
  196. /** 打开弹窗 */
  197. async open(id) {
  198. this.dialogVisible = true;
  199. this.reset();
  200. // 修改时,设置数据
  201. if (id) {
  202. this.formLoading = true;
  203. try {
  204. const res = await ${simpleClassName}Api.get${simpleClassName}(id);
  205. this.formData = res.data;
  206. this.title = "修改${table.classComment}";
  207. } finally {
  208. this.formLoading = false;
  209. }
  210. }
  211. this.title = "新增${table.classComment}";
  212. ## 特殊:树表专属逻辑
  213. #if ( $table.templateType == 2 )
  214. this.get${simpleClassName}Tree();
  215. #end
  216. },
  217. /** 提交按钮 */
  218. async submitForm() {
  219. // 校验主表
  220. await this.$refs["formRef"].validate();
  221. ## 特殊:主子表专属逻辑
  222. #if ( $table.templateType == 10 || $table.templateType == 12 )
  223. #if ( $subTables && $subTables.size() > 0 )
  224. // 校验子表
  225. #foreach ($subTable in $subTables)
  226. #set ($index = $foreach.count - 1)
  227. #set ($subClassNameVar = $subClassNameVars.get($index))
  228. try {
  229. ## 代码生成后会替换为正确的 refs
  230. await this.refs['${subClassNameVar}FormRef'].validate();
  231. } catch (e) {
  232. this.subTabsName = '${subClassNameVar}';
  233. return;
  234. }
  235. #end
  236. #end
  237. #end
  238. this.formLoading = true;
  239. try {
  240. const data = this.formData;
  241. ## 特殊:主子表专属逻辑
  242. #if ( $table.templateType == 10 || $table.templateType == 12 )
  243. #if ( $subTables && $subTables.size() > 0 )
  244. // 拼接子表的数据
  245. #foreach ($subTable in $subTables)
  246. #set ($index = $foreach.count - 1)
  247. #set ($subClassNameVar = $subClassNameVars.get($index))
  248. data.${subClassNameVar}#if ( $subTable.subJoinMany)s#end = this.refs['${subClassNameVar}FormRef'].getData();
  249. #end
  250. #end
  251. #end
  252. // 修改的提交
  253. if (data.${primaryColumn.javaField}) {
  254. await ${simpleClassName}Api.update${simpleClassName}(data);
  255. this.#[[$modal]]#.msgSuccess("修改成功");
  256. this.dialogVisible = false;
  257. this.#[[$]]#emit('success');
  258. return;
  259. }
  260. // 添加的提交
  261. await ${simpleClassName}Api.create${simpleClassName}(data);
  262. this.#[[$modal]]#.msgSuccess("新增成功");
  263. this.dialogVisible = false;
  264. this.#[[$]]#emit('success');
  265. }finally {
  266. this.formLoading = false;
  267. }
  268. },
  269. ## 特殊:树表专属逻辑
  270. #if ( $table.templateType == 2 )
  271. /** 获得${table.classComment}树 */
  272. async get${simpleClassName}Tree() {
  273. this.${classNameVar}Tree = [];
  274. const res = await ${simpleClassName}Api.get${simpleClassName}List();
  275. const root = { id: 0, name: '顶级${table.classComment}', children: [] };
  276. root.children = this.handleTree(res.data, 'id', '${treeParentColumn.javaField}')
  277. this.${classNameVar}Tree.push(root)
  278. },
  279. #end
  280. ## 特殊:树表专属逻辑
  281. #if ( $table.templateType == 2 )
  282. /** 转换${table.classComment}数据结构 */
  283. normalizer(node) {
  284. if (node.children && !node.children.length) {
  285. delete node.children;
  286. }
  287. #if ($treeNameColumn.javaField == "name")
  288. return {
  289. id: node.id,
  290. label: node.name,
  291. children: node.children
  292. };
  293. #else
  294. return {
  295. id: node.id,
  296. label: node['$treeNameColumn.javaField'],
  297. children: node.children
  298. };
  299. #end
  300. },
  301. #end
  302. /** 表单重置 */
  303. reset() {
  304. this.formData = {
  305. #foreach ($column in $columns)
  306. #if ($column.createOperation || $column.updateOperation)
  307. #if ($column.htmlType == "checkbox")
  308. $column.javaField: [],
  309. #else
  310. $column.javaField: undefined,
  311. #end
  312. #end
  313. #end
  314. };
  315. this.resetForm("formRef");
  316. }
  317. }
  318. };
  319. </script>