form.vue.vm 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  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. open(id) {
  198. this.dialogVisible = true;
  199. this.reset();
  200. const that = this;
  201. // 修改时,设置数据
  202. if (id) {
  203. this.formLoading = true;
  204. try {
  205. ${simpleClassName}Api.get${simpleClassName}(id).then(res=>{
  206. that.formData = res.data;
  207. that.title = "修改${table.classComment}";
  208. })
  209. } finally {
  210. this.formLoading = false;
  211. }
  212. }
  213. this.title = "新增${table.classComment}";
  214. ## 特殊:树表专属逻辑
  215. #if ( $table.templateType == 2 )
  216. this.get${simpleClassName}Tree()
  217. #end
  218. },
  219. /** 提交按钮 */
  220. submitForm() {
  221. this.formLoading = true;
  222. try {
  223. const that = this;
  224. let data = this.formData;
  225. let validate = false;
  226. // 校验主表
  227. this.getRef("formRef").validate(valid => {
  228. validate = valid;
  229. });
  230. ## 特殊:主子表专属逻辑
  231. #if ( $table.templateType == 10 || $table.templateType == 12 )
  232. #if ( $subTables && $subTables.size() > 0 )
  233. // 校验子表
  234. this.validateSubFrom01().then(() => {
  235. // 全部校验通过-拼接子表的数据
  236. // 拼接子表的数据
  237. #foreach ($subTable in $subTables)
  238. #set ($index = $foreach.count - 1)
  239. #set ($subClassNameVar = $subClassNameVars.get($index))
  240. data.${subClassNameVar}#if ( $subTable.subJoinMany)s#end = that.getRef('${subClassNameVar}FormRef').getData();
  241. #end
  242. }).catch((err) => {
  243. validate = false
  244. that.subTabsName = err.replace("FormRef", ""); // 定位到没有校验通过的子表单
  245. })
  246. #end
  247. #end
  248. // 所有表单校验通过后方可提交
  249. if (!validate) {
  250. return;
  251. }
  252. // 修改的提交
  253. if (data.${primaryColumn.javaField}) {
  254. ${simpleClassName}Api.update${simpleClassName}(data).then(response => {
  255. that.#[[$modal]]#.msgSuccess("修改成功");
  256. that.dialogVisible = false;
  257. that.#[[$]]#emit('success');
  258. });
  259. return;
  260. }
  261. // 添加的提交
  262. ${simpleClassName}Api.create${simpleClassName}(data).then(response => {
  263. that.#[[$modal]]#.msgSuccess("新增成功");
  264. that.dialogVisible = false;
  265. that.#[[$]]#emit('success');
  266. });
  267. }finally {
  268. this.formLoading = false
  269. }
  270. },
  271. getRef(refName){ // TODO puhui999: 获得表单 ref,提取出来的目的呢是解决 #[[$]]# 在 if 中 end闭合不了的问题,代码生成后可删除此方法
  272. return this.#[[$]]#refs[refName]
  273. },
  274. ## 特殊:主子表专属逻辑
  275. #if ( $table.templateType == 10 || $table.templateType == 12 )
  276. #if ( $subTables && $subTables.size() > 0 )
  277. /** 校验子表单 */
  278. validateSubFrom(item) {
  279. return new Promise((resolve, reject) => {
  280. this.$refs[item].validate()
  281. .then(() => {
  282. resolve()
  283. })
  284. .catch(() => {
  285. reject(item)
  286. })
  287. })
  288. },
  289. /** 校验所有子表单 */
  290. validateSubFrom01() {
  291. // 需要校验的表单 ref
  292. const validFormRefArr = [
  293. #foreach ($subTable in $subTables)
  294. #set ($index = $foreach.count - 1)
  295. #set ($subClassNameVar = $subClassNameVars.get($index))
  296. "${subClassNameVar}FormRef",
  297. #end
  298. ];
  299. const validArr = []; // 校验
  300. for (const item of validFormRefArr) {
  301. validArr.push(this.validateSubFrom(item))
  302. }
  303. return new Promise((resolve, reject) => {
  304. // 校验所有
  305. Promise.all(validArr).then(() => {
  306. resolve()
  307. }).catch((err) => {
  308. reject(err)
  309. })
  310. })
  311. },
  312. #end
  313. #end
  314. ## 特殊:树表专属逻辑
  315. #if ( $table.templateType == 2 )
  316. /** 获得${table.classComment}树 */
  317. get${simpleClassName}Tree() {
  318. const that = this;
  319. that.${classNameVar}Tree = [];
  320. ${simpleClassName}Api.get${simpleClassName}List().then(res=>{
  321. const root = { id: 0, name: '顶级${table.classComment}', children: [] };
  322. root.children = this.handleTree(res.data, 'id', '${treeParentColumn.javaField}')
  323. that.${classNameVar}Tree.push(root)
  324. });
  325. },
  326. #end
  327. ## 特殊:树表专属逻辑
  328. #if ( $table.templateType == 2 )
  329. /** 转换${table.classComment}数据结构 */
  330. normalizer(node) {
  331. if (node.children && !node.children.length) {
  332. delete node.children;
  333. }
  334. #if ($treeNameColumn.javaField == "name")
  335. return {
  336. id: node.id,
  337. label: node.name,
  338. children: node.children
  339. };
  340. #else
  341. return {
  342. id: node.id,
  343. label: node['$treeNameColumn.javaField'],
  344. children: node.children
  345. };
  346. #end
  347. },
  348. #end
  349. /** 表单重置 */
  350. reset() {
  351. this.formData = {
  352. #foreach ($column in $columns)
  353. #if ($column.createOperation || $column.updateOperation)
  354. #if ($column.htmlType == "checkbox")
  355. $column.javaField: [],
  356. #else
  357. $column.javaField: undefined,
  358. #end
  359. #end
  360. #end
  361. };
  362. this.resetForm("formRef");
  363. },
  364. }
  365. };
  366. </script>