代码生成优化

pull/38/head
RuoYi 2018-11-21 23:37:09 +08:00
parent 4fed9a1e50
commit c96b73bbda
11 changed files with 284 additions and 39 deletions

View File

@ -2,20 +2,16 @@
2018年度最受欢迎中国开源软件评选 2018年度最受欢迎中国开源软件评选
请给若依/RuoYi 投票,谢谢支持 请给若依/RuoYi 投票,谢谢大家
https://www.oschina.net/project/top_cn_2018?sort=1 https://www.oschina.net/project/top_cn_2018?sort=1
一直想做一款后台管理系统看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间开始自己写了一套后台系统。如此有了若依。她可以用于所有的Web应用程序如网站管理后台网站会员中心CMSCRMOA。所有前端后台代码封装过后十分精简易上手出错概率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。 一直想做一款后台管理系统看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间开始自己写了一套后台系统。如此有了若依。她可以用于所有的Web应用程序如网站管理后台网站会员中心CMSCRMOA。所有前端后台代码封装过后十分精简易上手出错概率低。同时支持移动客户端访问。系统会陆续更新一些实用功能。
性别男,若依是女儿的名字。 寓意:你若不离不弃,我必生死相依
若依基于hplus和inspinia两套后台系统模板开发。有需要可自行到群内下载。 若依基于hplus和inspinia两套后台系统模板开发。有需要可自行到群内下载。
http://www.zi-han.net/theme/hplus
http://webapplayers.com/inspinia_admin-v2.7.1
> RuoYi从3.0开始,进行模块拆分,将原先的单应用转变为多模块,如需单应用,请移步 [RuoYi-fast](https://gitee.com/y_project/RuoYi-fast) > RuoYi从3.0开始,进行模块拆分,将原先的单应用转变为多模块,如需单应用,请移步 [RuoYi-fast](https://gitee.com/y_project/RuoYi-fast)
> 推荐使用阿里云部署,通用云产品代金券 [点我领取](https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=brki8iof) > 推荐使用阿里云部署,通用云产品代金券 [点我领取](https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=brki8iof)
@ -41,7 +37,9 @@ http://webapplayers.com/inspinia_admin-v2.7.1
## 在线体验 ## 在线体验
> admin/admin123 > admin/admin123
地址http://www.ruoyi.vip 演示地址http://ruoyi.vip
文档地址http://doc.ruoyi.vip
## 演示图 ## 演示图

View File

@ -126,8 +126,8 @@ xss:
gen: gen:
# 作者 # 作者
author: ruoyi author: ruoyi
# 默认生成包路径 module 需改成自己的模块名称 如 system monitor tool # 默认生成包路径 system 需改成自己的模块名称 如 system monitor tool
packageName: com.ruoyi.module packageName: com.ruoyi.system
# 自动去除表前缀默认是true # 自动去除表前缀默认是true
autoRemovePre: true autoRemovePre: true
# 表前缀(类名不会包含表前缀) # 表前缀(类名不会包含表前缀)

View File

@ -68,6 +68,22 @@ $(function() {
}); });
}); });
} }
// laydate time-input 时间控件绑定
if ($(".time-input").length > 0) {
layui.use('laydate', function() {
var laydate = layui.laydate;
var times = $(".time-input");
for (var i = 0; i < times.length; i++) {
var time = times[i];
laydate.render({
elem: time,
theme: 'molv',
trigger: 'click',
done: function(value, date) {}
});
}
});
}
// tree 关键字搜索绑定 // tree 关键字搜索绑定
if ($("#keyword").length > 0) { if ($("#keyword").length > 0) {
$("#keyword").bind("focus", function focusKey(e) { $("#keyword").bind("focus", function focusKey(e) {

View File

@ -0,0 +1,72 @@
package com.ruoyi.generator.domain;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
/**
*
* :{"title": "状态", "type": "dict", "value": "sys_common_status"} {"title": "登录时间", "type": "date"}
*
* @author ruoyi
*
*/
@JsonIgnoreProperties(ignoreUnknown = true)
public class ColumnConfigInfo
{
/**
*
*/
private String title;
/**
* dict(value), date(date)
*/
private String type;
/**
*
*/
private String value;
public ColumnConfigInfo()
{
super();
}
public ColumnConfigInfo(String title, String type, String value)
{
super();
this.title = title;
this.type = type;
this.value = value;
}
public String getTitle()
{
return title;
}
public void setTitle(String title)
{
this.title = title;
}
public String getType()
{
return type;
}
public void setType(String type)
{
this.type = type;
}
public String getValue()
{
return value;
}
public void setValue(String value)
{
this.value = value;
}
}

View File

@ -1,5 +1,8 @@
package com.ruoyi.generator.domain; package com.ruoyi.generator.domain;
import com.ruoyi.common.json.JSON;
import com.ruoyi.common.utils.StringUtils;
/** /**
* ry * ry
* *
@ -15,6 +18,9 @@ public class ColumnInfo
/** 列描述 */ /** 列描述 */
private String columnComment; private String columnComment;
/** 列配置 */
private ColumnConfigInfo configInfo;
/** Java属性类型 */ /** Java属性类型 */
private String attrType; private String attrType;
@ -50,9 +56,18 @@ public class ColumnInfo
return columnComment; return columnComment;
} }
public void setColumnComment(String columnComment) public void setColumnComment(String columnComment) throws Exception
{ {
this.columnComment = columnComment; // 根据列描述解析列的配置信息
if (StringUtils.isNotEmpty(columnComment) && columnComment.startsWith("{"))
{
this.configInfo = JSON.unmarshal(columnComment, ColumnConfigInfo.class);
this.columnComment = configInfo.getTitle();
}
else
{
this.columnComment = columnComment;
}
} }
public String getAttrName() public String getAttrName()
@ -84,4 +99,14 @@ public class ColumnInfo
{ {
this.attrType = attrType; this.attrType = attrType;
} }
public ColumnConfigInfo getConfigInfo()
{
return configInfo;
}
public void setConfigInfo(ColumnConfigInfo configInfo)
{
this.configInfo = configInfo;
}
} }

View File

@ -23,7 +23,7 @@ public class GenUtils
private static final String PROJECT_PATH = "main/java/com/ruoyi"; private static final String PROJECT_PATH = "main/java/com/ruoyi";
/** mybatis空间路径 */ /** mybatis空间路径 */
private static final String MYBATIS_PATH = "main/resources/mybatis"; private static final String MYBATIS_PATH = "main/resources/mapper";
/** html空间路径 */ /** html空间路径 */
private static final String TEMPLATES_PATH = "main/resources/templates"; private static final String TEMPLATES_PATH = "main/resources/templates";
@ -69,8 +69,9 @@ public class GenUtils
velocityContext.put("primaryKey", table.getPrimaryKey()); velocityContext.put("primaryKey", table.getPrimaryKey());
velocityContext.put("className", table.getClassName()); velocityContext.put("className", table.getClassName());
velocityContext.put("classname", table.getClassname()); velocityContext.put("classname", table.getClassname());
velocityContext.put("moduleName", GenUtils.getModuleName(packageName)); velocityContext.put("moduleName", getModuleName(packageName));
velocityContext.put("columns", table.getColumns()); velocityContext.put("columns", table.getColumns());
velocityContext.put("basePackage", getBasePackage(packageName));
velocityContext.put("package", packageName); velocityContext.put("package", packageName);
velocityContext.put("author", Global.getAuthor()); velocityContext.put("author", Global.getAuthor());
velocityContext.put("datetime", DateUtils.getDate()); velocityContext.put("datetime", DateUtils.getDate());
@ -144,7 +145,7 @@ public class GenUtils
if (template.contains("ServiceImpl.java.vm")) if (template.contains("ServiceImpl.java.vm"))
{ {
return javaPath + "service" + "/" + className + "ServiceImpl.java"; return javaPath + "service" + "/" + "/impl/" + className + "ServiceImpl.java";
} }
if (template.contains("Controller.java.vm")) if (template.contains("Controller.java.vm"))
@ -190,6 +191,13 @@ public class GenUtils
return moduleName; return moduleName;
} }
public static String getBasePackage(String packageName)
{
int lastIndex = packageName.lastIndexOf(".");
String basePackage = StringUtils.substring(packageName, 0, lastIndex);
return basePackage;
}
public static String replaceKeyword(String keyword) public static String replaceKeyword(String keyword)
{ {
String keyName = keyword.replaceAll("(?:表|信息)", ""); String keyName = keyword.replaceAll("(?:表|信息)", "");
@ -224,6 +232,6 @@ public class GenUtils
{ {
System.out.println(StringUtils.convertToCamelCase("user_name")); System.out.println(StringUtils.convertToCamelCase("user_name"));
System.out.println(replaceKeyword("岗位信息表")); System.out.println(replaceKeyword("岗位信息表"));
System.out.println(getModuleName("com.ruoyi.system")); System.out.println(getBasePackage("com.ruoyi.system"));
} }
} }

View File

@ -7,12 +7,33 @@
<form class="form-horizontal m" id="form-${classname}-add"> <form class="form-horizontal m" id="form-${classname}-add">
#foreach($column in $columns) #foreach($column in $columns)
#if($column.columnName != $primaryKey.columnName) #if($column.columnName != $primaryKey.columnName)
#if(!${column.configInfo})
<div class="form-group"> <div class="form-group">
<label class="col-sm-3 control-label">${column.columnComment}</label> <label class="col-sm-3 control-label">${column.columnComment}</label>
<div class="col-sm-8"> <div class="col-sm-8">
<input id="${column.attrname}" name="${column.attrname}" class="form-control" type="text"> <input id="${column.attrname}" name="${column.attrname}" class="form-control" type="text">
</div> </div>
</div> </div>
#else
#if(${column.configInfo.type} == "dict")
<div class="form-group">
<label class="col-sm-3 control-label">${column.columnComment}</label>
<div class="col-sm-8">
<select name="${column.attrname}" class="form-control m-b" th:with="type=${@dict.getType('${column.configInfo.value}')}">
<option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
</select>
</div>
</div>
#elseif(${column.configInfo.type} == "date")
<div class="form-group">
<label class="col-sm-3 control-label">${column.columnComment}</label>
<div class="col-sm-8">
<input id="${column.attrname}" name="${column.attrname}" class="form-control time-input" type="text">
</div>
</div>
#elseif(${column.configInfo.type} == "fk")
#end
#end
#end #end
#end #end
</form> </form>

View File

@ -8,12 +8,33 @@
<input id="${primaryKey.attrname}" name="${primaryKey.attrname}" th:field="*{${primaryKey.attrname}}" type="hidden"> <input id="${primaryKey.attrname}" name="${primaryKey.attrname}" th:field="*{${primaryKey.attrname}}" type="hidden">
#foreach($column in $columns) #foreach($column in $columns)
#if($column.columnName != $primaryKey.columnName) #if($column.columnName != $primaryKey.columnName)
<div class="form-group"> #if(!${column.configInfo})
<label class="col-sm-3 control-label">${column.columnComment}</label> <div class="form-group">
<div class="col-sm-8"> <label class="col-sm-3 control-label">${column.columnComment}</label>
<input id="${column.attrname}" name="${column.attrname}" th:field="*{${column.attrname}}" class="form-control" type="text"> <div class="col-sm-8">
</div> <input id="${column.attrname}" name="${column.attrname}" th:field="*{${column.attrname}}" class="form-control" type="text">
</div> </div>
</div>
#else
#if(${column.configInfo.type} == "dict")
<div class="form-group">
<label class="col-sm-3 control-label">${column.columnComment}</label>
<div class="col-sm-8">
<select name="${column.attrname}" class="form-control m-b" th:with="type=${@dict.getType('${column.configInfo.value}')}">
<option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}" th:field="*{${column.attrname}}"></option>
</select>
</div>
</div>
#elseif(${column.configInfo.type} == "date")
<div class="form-group">
<label class="col-sm-3 control-label">${column.columnComment}</label>
<div class="col-sm-8">
<input id="${column.attrname}" name="${column.attrname}" th:field="*{${column.attrname}}" class="form-control time-input" type="text">
</div>
</div>
#elseif(${column.configInfo.type} == "fk")
#end
#end
#end #end
#end #end
</form> </form>

View File

@ -3,23 +3,68 @@
<meta charset="utf-8"> <meta charset="utf-8">
<head th:include="include :: header"></head> <head th:include="include :: header"></head>
<body class="gray-bg"> <body class="gray-bg">
<div class="container-div">
<div class="btn-group-sm hidden-xs" id="toolbar" role="group"> <div class="container-div">
<a class="btn btn-success" onclick="$.operate.add()" shiro:hasPermission="${moduleName}:${classname}:add"> <div class="row">
<i class="fa fa-plus"></i> 添加 <div class="col-sm-12 search-collapse">
</a> <form id="formId">
<a class="btn btn-primary btn-edit disabled" onclick="$.operate.edit()" shiro:hasPermission="${moduleName}:${classname}:edit"> <div class="select-list">
<i class="fa fa-edit"></i> 修改 <ul>
</a> #foreach($column in $columns)
<a class="btn btn-danger btn-del btn-del disabled" onclick="$.operate.removeAll()" shiro:hasPermission="${moduleName}:${classname}:remove"> #if($column.columnName != $primaryKey.columnName)
<i class="fa fa-remove"></i> 删除 #if(!${column.configInfo})
</a> <li>
</div> ${column.columnComment}<input type="text" name="${column.attrname}"/>
</li>
#else
#if(${column.configInfo.type} == "dict")
<li>
${column.columnComment}<select name="${column.attrname}" th:with="type=${@dict.getType('${column.configInfo.value}')}">
<option value="">所有</option>
<option th:each="dict : ${type}" th:text="${dict.dictLabel}" th:value="${dict.dictValue}"></option>
</select>
</li>
#elseif(${column.configInfo.type} == "date")
<li class="select-time">
<label>${column.columnComment} </label>
<input type="text" class="time-input" id="start${column.attrName}" placeholder="开始" name="params[begin${column.attrName}]"/>
<span>-</span>
<input type="text" class="time-input" id="end${column.attrName}" placeholder="结束" name="params[end${column.attrName}]"/>
</li>
#elseif(${column.configInfo.type} == "fk")
#end
#end
#end
#end
<li>
<a class="btn btn-primary btn-rounded btn-sm" onclick="$.table.search()"><i class="fa fa-search"></i>&nbsp;搜索</a>
<a class="btn btn-warning btn-rounded btn-sm" onclick="$.form.reset()"><i class="fa fa-refresh"></i>&nbsp;重置</a>
</li>
</ul>
</div>
</form>
</div>
<div class="col-sm-12 select-table table-striped"> <div class="btn-group-sm hidden-xs" id="toolbar" role="group">
<table id="bootstrap-table" data-mobile-responsive="true"></table> <a class="btn btn-success" onclick="$.operate.add()" shiro:hasPermission="${moduleName}:${classname}:add">
<i class="fa fa-plus"></i> 添加
</a>
<a class="btn btn-primary btn-edit disabled" onclick="$.operate.edit()" shiro:hasPermission="${moduleName}:${classname}:edit">
<i class="fa fa-edit"></i> 修改
</a>
<a class="btn btn-danger btn-del btn-del disabled" onclick="$.operate.removeAll()" shiro:hasPermission="${moduleName}:${classname}:remove">
<i class="fa fa-remove"></i> 删除
</a>
<a class="btn btn-warning" onclick="$.table.exportExcel()" shiro:hasPermission="${moduleName}:${classname}:export">
<i class="fa fa-download"></i> 导出
</a>
</div>
<div class="col-sm-12 select-table table-striped">
<table id="bootstrap-table" data-mobile-responsive="true"></table>
</div>
</div> </div>
</div> </div>
<div th:include="include :: footer"></div> <div th:include="include :: footer"></div>
<script th:inline="javascript"> <script th:inline="javascript">
var editFlag = [[${@permission.hasPermi('${moduleName}:${classname}:edit')}]]; var editFlag = [[${@permission.hasPermi('${moduleName}:${classname}:edit')}]];
@ -32,15 +77,39 @@
createUrl: prefix + "/add", createUrl: prefix + "/add",
updateUrl: prefix + "/edit/{id}", updateUrl: prefix + "/edit/{id}",
removeUrl: prefix + "/remove", removeUrl: prefix + "/remove",
exportUrl: prefix + "/export",
modalName: "${tableComment}", modalName: "${tableComment}",
search: false,
showExport: true,
columns: [{ columns: [{
checkbox: true checkbox: true
}, },
#foreach($column in $columns) #foreach($column in $columns)
#if($column.columnName == $primaryKey.columnName)
{ {
field : '${column.attrname}', field : '${column.attrname}',
title : '${column.columnComment}' title : '${column.columnComment}',
visible: false
}, },
#elseif($column.columnName != $primaryKey.columnName)
#if(${column.configInfo} && ${column.configInfo.type} == 'dict')
{
field : '${column.attrname}',
title : '${column.columnComment}',
sortable: true,
formatter: function(value, row, index) {
var datas = [[${@dict.getType('${column.configInfo.value}')}]];
return $.table.selectDictLabel(datas, value);
}
},
#else
{
field : '${column.attrname}',
title : '${column.columnComment}',
sortable: true
},
#end
#end
#end #end
{ {
title: '操作', title: '操作',

View File

@ -1,4 +1,4 @@
package ${package}.web.controller; package ${basePackage}.web.controller.${moduleName};
import java.util.List; import java.util.List;
import org.apache.shiro.authz.annotation.RequiresPermissions; import org.apache.shiro.authz.annotation.RequiresPermissions;
@ -17,6 +17,7 @@ import ${package}.service.I${className}Service;
import com.ruoyi.framework.web.base.BaseController; import com.ruoyi.framework.web.base.BaseController;
import com.ruoyi.framework.web.page.TableDataInfo; import com.ruoyi.framework.web.page.TableDataInfo;
import com.ruoyi.common.base.AjaxResult; import com.ruoyi.common.base.AjaxResult;
import com.ruoyi.common.utils.ExcelUtil;
/** /**
* ${tableComment} 信息操作处理 * ${tableComment} 信息操作处理
@ -53,6 +54,20 @@ public class ${className}Controller extends BaseController
return getDataTable(list); return getDataTable(list);
} }
/**
* 导出${tableComment}列表
*/
@RequiresPermissions("${moduleName}:${classname}:export")
@PostMapping("/export")
@ResponseBody
public AjaxResult export(${className} ${classname})
{
List<${className}> list = ${classname}Service.select${className}List(${classname});
ExcelUtil<${className}> util = new ExcelUtil<${className}>(${className}.class);
return util.exportExcel(list, "${classname}");
}
/** /**
* 新增${tableComment} * 新增${tableComment}
*/ */

View File

@ -1,4 +1,4 @@
package ${package}.service; package ${package}.service.impl;
import java.util.List; import java.util.List;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;