controller.java.vm 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. package ${packageName}.controller;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  4. import com.jiayue.common.annotation.Log;
  5. import com.jiayue.common.core.controller.BaseController;
  6. import com.jiayue.common.core.domain.AjaxResult;
  7. import com.jiayue.common.enums.BusinessType;
  8. import com.jiayue.common.utils.poi.ExcelUtil;
  9. import org.springframework.beans.factory.annotation.Autowired;
  10. import org.springframework.security.access.prepost.PreAuthorize;
  11. import org.springframework.web.bind.annotation.DeleteMapping;
  12. import org.springframework.web.bind.annotation.GetMapping;
  13. import org.springframework.web.bind.annotation.PathVariable;
  14. import org.springframework.web.bind.annotation.PostMapping;
  15. import org.springframework.web.bind.annotation.PutMapping;
  16. import org.springframework.web.bind.annotation.RequestBody;
  17. import org.springframework.web.bind.annotation.RequestMapping;
  18. import org.springframework.web.bind.annotation.RestController;
  19. import java.util.Arrays;
  20. import java.util.List;
  21. import javax.servlet.http.HttpServletResponse;
  22. import cn.hutool.core.util.ObjectUtil;
  23. import cn.hutool.core.util.StrUtil;
  24. import lombok.RequiredArgsConstructor;
  25. import ${packageName}.domain.${ClassName};
  26. import ${packageName}.service.I${ClassName}Service;
  27. #if($table.crud || $table.sub)
  28. import com.jiayue.common.core.page.TableDataInfo;
  29. #elseif($table.tree)
  30. #end
  31. /**
  32. * ${functionName}Controller
  33. *
  34. * @author ${author}
  35. * @date ${datetime}
  36. */
  37. @RequiredArgsConstructor(onConstructor_ = @Autowired)
  38. @RestController
  39. @RequestMapping("/${moduleName}/${businessName}")
  40. public class ${ClassName}Controller extends BaseController {
  41. private final I${ClassName}Service i${ClassName}Service;
  42. /**
  43. * 查询${functionName}列表
  44. */
  45. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:list')")
  46. @GetMapping("/list")
  47. #if($table.crud || $table.sub)
  48. public TableDataInfo list(${ClassName} ${className}) {
  49. startPage();
  50. LambdaQueryWrapper<${ClassName}> queryWrapper = this.buildQueryParams(${className});
  51. List<${ClassName}> list = i${ClassName}Service.list(queryWrapper);
  52. return getDataTable(list);
  53. }
  54. #elseif($table.tree)
  55. public AjaxResult list(${ClassName} ${className}) {
  56. LambdaQueryWrapper<${ClassName}> queryWrapper = Wrappers.lambdaQuery(${className});
  57. List<${ClassName}> list = i${ClassName}Service.list(queryWrapper);
  58. return AjaxResult.success(list);
  59. }
  60. #end
  61. /**
  62. * 导出${functionName}列表
  63. */
  64. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:export')")
  65. @Log(title = "${functionName}", businessType = BusinessType.EXPORT)
  66. @PostMapping("/export")
  67. public void export(HttpServletResponse response, ${ClassName} ${className}) {
  68. LambdaQueryWrapper<${ClassName}> queryWrapper = this.buildQueryParams(${className});
  69. List<${ClassName}> list = i${ClassName}Service.list(queryWrapper);
  70. ExcelUtil<${ClassName}> util = new ExcelUtil<>(${ClassName}. class);
  71. util.exportExcel(response, list, "${functionName}数据");
  72. }
  73. /**
  74. * 获取${functionName}详细信息
  75. */
  76. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:query')")
  77. @GetMapping(value = "/{${pkColumn.javaField}}")
  78. public AjaxResult getInfo(@PathVariable("${pkColumn.javaField}") ${pkColumn.javaType} ${pkColumn.javaField}) {
  79. return AjaxResult.success(i${ClassName}Service.getById(${pkColumn.javaField}));
  80. }
  81. /**
  82. * 新增${functionName}
  83. */
  84. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:add')")
  85. @Log(title = "${functionName}", businessType = BusinessType.INSERT)
  86. @PostMapping
  87. public AjaxResult add(@RequestBody ${ClassName} ${className}) {
  88. return toAjax(i${ClassName}Service.save(${className}) ? 1 : 0);
  89. }
  90. /**
  91. * 修改${functionName}
  92. */
  93. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:edit')")
  94. @Log(title = "${functionName}", businessType = BusinessType.UPDATE)
  95. @PutMapping
  96. public AjaxResult edit(@RequestBody ${ClassName} ${className}) {
  97. return toAjax(i${ClassName}Service.updateById(${className}) ? 1 : 0);
  98. }
  99. /**
  100. * 删除${functionName}
  101. */
  102. @PreAuthorize("@ss.hasPermi('${permissionPrefix}:remove')")
  103. @Log(title = "${functionName}", businessType = BusinessType.DELETE)
  104. @DeleteMapping("/{${pkColumn.javaField}s}")
  105. public AjaxResult remove(@PathVariable ${pkColumn.javaType}[]${pkColumn.javaField}s) {
  106. return toAjax(i${ClassName}Service.removeByIds(Arrays.asList(${pkColumn.javaField}s)) ? 1 : 0);
  107. }
  108. /**
  109. * 构建查询条件
  110. **/
  111. private LambdaQueryWrapper<${ClassName}> buildQueryParams(${ClassName} ${className}) {
  112. LambdaQueryWrapper<${ClassName}> queryWrapper = Wrappers.lambdaQuery();
  113. #foreach($column in $columns)
  114. #set($queryType=$column.queryType)
  115. #set($javaField=$column.javaField)
  116. #set($javaType=$column.javaType)
  117. #set($columnName=$column.columnName)
  118. #set($AttrName=$column.javaField.substring(0,1).toUpperCase() + ${column.javaField.substring(1)})
  119. #if($column.query)
  120. #if($column.queryType == "EQ")
  121. #if($javaType == 'String')
  122. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  123. queryWrapper.eq(${ClassName}::get$AttrName ,${className}.get$AttrName());
  124. }
  125. #else
  126. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  127. queryWrapper.eq(${ClassName}::get$AttrName ,${className}.get$AttrName());
  128. }
  129. #end
  130. #elseif($queryType == "NE")
  131. #if($javaType == 'String')
  132. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  133. queryWrapper.ne(${ClassName}::get$AttrName ,${className}.get$AttrName());
  134. }
  135. #else
  136. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  137. queryWrapper.ne(${ClassName}::get$AttrName ,${className}.get$AttrName());
  138. }
  139. #end
  140. #elseif($queryType == "GT")
  141. #if($javaType == 'String')
  142. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  143. queryWrapper.gt(${ClassName}::get$AttrName ,${className}.get$AttrName());
  144. }
  145. #else
  146. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  147. queryWrapper.gt(${ClassName}::get$AttrName ,${className}.get$AttrName());
  148. }
  149. #end
  150. #elseif($queryType == "GTE")
  151. #if($javaType == 'String')
  152. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  153. queryWrapper.ge(${ClassName}::get$AttrName ,${className}.get$AttrName());
  154. }
  155. #else
  156. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  157. queryWrapper.ge(${ClassName}::get$AttrName ,${className}.get$AttrName());
  158. }
  159. #end
  160. #elseif($queryType == "LT")
  161. #if($javaType == 'String')
  162. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  163. queryWrapper.lt(${ClassName}::get$AttrName ,${className}.get$AttrName());
  164. }
  165. #else
  166. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  167. queryWrapper.lt(${ClassName}::get$AttrName ,${className}.get$AttrName());
  168. }
  169. #end
  170. #elseif($queryType == "LTE")
  171. #if($javaType == 'String')
  172. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  173. queryWrapper.le(${ClassName}::get$AttrName ,${className}.get$AttrName());
  174. }
  175. #else
  176. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  177. queryWrapper.le(${ClassName}::get$AttrName ,${className}.get$AttrName());
  178. }
  179. #end
  180. #elseif($queryType == "LIKE")
  181. #if($javaType == 'String')
  182. if (StrUtil.isNotBlank(${className}.get$AttrName())) {
  183. queryWrapper.like(${ClassName}::get$AttrName ,${className}.get$AttrName());
  184. }
  185. #else
  186. if (ObjectUtil.isNotNull(${className}.get$AttrName())) {
  187. queryWrapper.like(${ClassName}::get$AttrName ,${className}.get$AttrName());
  188. }
  189. #end
  190. #elseif($queryType == "BETWEEN")
  191. #end
  192. #end
  193. #end
  194. return queryWrapper;
  195. }
  196. }