20 changed files with 1339 additions and 1 deletions
@ -0,0 +1,151 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
package $!{package.Controller}; |
||||||
|
|
||||||
|
import io.swagger.annotations.Api; |
||||||
|
import io.swagger.annotations.ApiOperation; |
||||||
|
import io.swagger.annotations.ApiParam; |
||||||
|
import lombok.AllArgsConstructor; |
||||||
|
import javax.validation.Valid; |
||||||
|
|
||||||
|
import org.springblade.core.mp.support.Condition; |
||||||
|
import org.springblade.core.mp.support.Query; |
||||||
|
import org.springblade.system.feign.IDictClient; |
||||||
|
import org.springblade.core.tool.api.R; |
||||||
|
import org.springblade.core.tool.utils.Func; |
||||||
|
import org.springframework.web.bind.annotation.*; |
||||||
|
#if($!{superEntityClass}) |
||||||
|
import org.springframework.web.bind.annotation.RequestParam; |
||||||
|
#end |
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
import $!{voPackage}.$!{entity}VO; |
||||||
|
#set($wrapperPackage=$package.Entity.replace("entity","wrapper")) |
||||||
|
import $!{wrapperPackage}.$!{entity}Wrapper; |
||||||
|
import $!{package.Service}.$!{table.serviceName}; |
||||||
|
#if($!{superControllerClassPackage}) |
||||||
|
import $!{superControllerClassPackage}; |
||||||
|
#end |
||||||
|
#if(!$!{superEntityClass}) |
||||||
|
#end |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment} 控制器 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
@RestController |
||||||
|
@AllArgsConstructor |
||||||
|
@RequestMapping("#if($!{package.ModuleName})/$!{package.ModuleName}#end/$!{table.entityPath}") |
||||||
|
@Api(value = "$!{table.comment}", tags = "$!{table.comment}接口") |
||||||
|
#if($!{superControllerClass}) |
||||||
|
public class $!{table.controllerName} extends $!{superControllerClass} { |
||||||
|
#else |
||||||
|
public class $!{table.controllerName} { |
||||||
|
#end |
||||||
|
|
||||||
|
private $!{table.serviceName} $!{table.entityPath}Service; |
||||||
|
|
||||||
|
private IDictClient dictClient; |
||||||
|
|
||||||
|
/** |
||||||
|
* 详情 |
||||||
|
*/ |
||||||
|
@GetMapping("/detail") |
||||||
|
@ApiOperation(value = "详情", notes = "传入$!{table.entityPath}", position = 1) |
||||||
|
public R<$!{entity}VO> detail($!{entity} $!{table.entityPath}) { |
||||||
|
$!{entity} detail = $!{table.entityPath}Service.getOne(Condition.getQueryWrapper($!{table.entityPath})); |
||||||
|
$!{entity}Wrapper $!{table.entityPath}Wrapper = new $!{entity}Wrapper(dictClient); |
||||||
|
return R.data($!{table.entityPath}Wrapper.entityVO(detail)); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 分页 $!{table.comment} |
||||||
|
*/ |
||||||
|
@GetMapping("/list") |
||||||
|
@ApiOperation(value = "分页", notes = "传入$!{table.entityPath}", position = 2) |
||||||
|
public R<IPage<$!{entity}VO>> list($!{entity} $!{table.entityPath}, Query query) { |
||||||
|
IPage<$!{entity}> pages = $!{table.entityPath}Service.page(Condition.getPage(query), Condition.getQueryWrapper($!{table.entityPath})); |
||||||
|
$!{entity}Wrapper $!{table.entityPath}Wrapper = new $!{entity}Wrapper(dictClient); |
||||||
|
return R.data($!{table.entityPath}Wrapper.pageVO(pages)); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 自定义分页 $!{table.comment} |
||||||
|
*/ |
||||||
|
@GetMapping("/page") |
||||||
|
@ApiOperation(value = "分页", notes = "传入$!{table.entityPath}", position = 3) |
||||||
|
public R<IPage<$!{entity}VO>> page($!{entity}VO $!{table.entityPath}, Query query) { |
||||||
|
IPage<$!{entity}VO> pages = $!{table.entityPath}Service.select$!{entity}Page(Condition.getPage(query), $!{table.entityPath}); |
||||||
|
return R.data(pages); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 新增 $!{table.comment} |
||||||
|
*/ |
||||||
|
@PostMapping("/save") |
||||||
|
@ApiOperation(value = "新增", notes = "传入$!{table.entityPath}", position = 4) |
||||||
|
public R save(@Valid @RequestBody $!{entity} $!{table.entityPath}) { |
||||||
|
return R.status($!{table.entityPath}Service.save($!{table.entityPath})); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 修改 $!{table.comment} |
||||||
|
*/ |
||||||
|
@PostMapping("/update") |
||||||
|
@ApiOperation(value = "修改", notes = "传入$!{table.entityPath}", position = 5) |
||||||
|
public R update(@Valid @RequestBody $!{entity} $!{table.entityPath}) { |
||||||
|
return R.status($!{table.entityPath}Service.updateById($!{table.entityPath})); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 新增或修改 $!{table.comment} |
||||||
|
*/ |
||||||
|
@PostMapping("/submit") |
||||||
|
@ApiOperation(value = "新增或修改", notes = "传入$!{table.entityPath}", position = 6) |
||||||
|
public R submit(@Valid @RequestBody $!{entity} $!{table.entityPath}) { |
||||||
|
return R.status($!{table.entityPath}Service.saveOrUpdate($!{table.entityPath})); |
||||||
|
} |
||||||
|
|
||||||
|
#if($!{superEntityClass}) |
||||||
|
|
||||||
|
/** |
||||||
|
* 删除 $!{table.comment} |
||||||
|
*/ |
||||||
|
@PostMapping("/remove") |
||||||
|
@ApiOperation(value = "逻辑删除", notes = "传入ids", position = 7) |
||||||
|
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { |
||||||
|
return R.status($!{table.entityPath}Service.deleteLogic(Func.toIntList(ids))); |
||||||
|
} |
||||||
|
|
||||||
|
#else |
||||||
|
|
||||||
|
/** |
||||||
|
* 删除 $!{table.comment} |
||||||
|
*/ |
||||||
|
@PostMapping("/remove") |
||||||
|
@ApiOperation(value = "物理删除", notes = "传入ids", position = 7) |
||||||
|
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { |
||||||
|
return R.status($!{table.entityPath}Service.removeByIds(Func.toIntList(ids))); |
||||||
|
} |
||||||
|
|
||||||
|
#end |
||||||
|
|
||||||
|
} |
@ -0,0 +1,162 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
package $!{package.Entity}; |
||||||
|
|
||||||
|
#foreach($pkg in $!{table.importPackages}) |
||||||
|
import $!{pkg}; |
||||||
|
#end |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
import lombok.Data; |
||||||
|
import lombok.EqualsAndHashCode; |
||||||
|
#end |
||||||
|
#if($!{swagger2}) |
||||||
|
import io.swagger.annotations.ApiModel; |
||||||
|
import io.swagger.annotations.ApiModelProperty; |
||||||
|
#end |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment}实体类 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
@Data |
||||||
|
#end |
||||||
|
#if($!{table.convert}) |
||||||
|
@TableName("$!{table.name}") |
||||||
|
#end |
||||||
|
#if($!{superEntityClass}) |
||||||
|
@EqualsAndHashCode(callSuper = true) |
||||||
|
#end |
||||||
|
#if($!{swagger2}) |
||||||
|
@ApiModel(value = "$!{entity}对象", description = #if ("$!{table.comment}"=="")"$!{entity}对象"#else"$!{table.comment}"#end) |
||||||
|
#end |
||||||
|
#if($!{superEntityClass}) |
||||||
|
public class $!{entity} extends $!{superEntityClass}#if($!{activeRecord})<$!{entity}>#end { |
||||||
|
#elseif($!{activeRecord}) |
||||||
|
@Accessors(chain = true) |
||||||
|
public class $!{entity} extends Model<$!{entity}> { |
||||||
|
#else |
||||||
|
public class $!{entity} implements Serializable { |
||||||
|
#end |
||||||
|
|
||||||
|
private static final long serialVersionUID = 1L; |
||||||
|
|
||||||
|
## ---------- BEGIN 字段循环遍历 ---------- |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
#if($!{field.keyFlag}) |
||||||
|
#set($keyPropertyName=$!{field.propertyName}) |
||||||
|
#end |
||||||
|
#if("$!field.comment" != "") |
||||||
|
/** |
||||||
|
* $!{field.comment} |
||||||
|
*/ |
||||||
|
#if($!{swagger2}) |
||||||
|
@ApiModelProperty(value = "$!{field.comment}") |
||||||
|
#end |
||||||
|
#end |
||||||
|
#if($!{field.keyFlag}) |
||||||
|
## 主键 |
||||||
|
#if($!{field.keyIdentityFlag}) |
||||||
|
@TableId(value = "$!{field.name}", type = IdType.AUTO) |
||||||
|
#elseif(!$null.isNull($!{idType}) && "$!idType" != "") |
||||||
|
@TableId(value = "$!{field.name}", type = IdType.$!{idType}) |
||||||
|
#elseif($!{field.convert}) |
||||||
|
@TableId("$!{field.name}") |
||||||
|
#end |
||||||
|
## 普通字段 |
||||||
|
#elseif($!{field.fill}) |
||||||
|
## ----- 存在字段填充设置 ----- |
||||||
|
#if($!{field.convert}) |
||||||
|
@TableField(value = "$!{field.name}", fill = FieldFill.$!{field.fill}) |
||||||
|
#else |
||||||
|
@TableField(fill = FieldFill.$!{field.fill}) |
||||||
|
#end |
||||||
|
#elseif($!{field.convert}) |
||||||
|
@TableField("$!{field.name}") |
||||||
|
#end |
||||||
|
## 乐观锁注解 |
||||||
|
#if($!{versionFieldName}==$!{field.name}) |
||||||
|
@Version |
||||||
|
#end |
||||||
|
## 逻辑删除注解 |
||||||
|
#if($!{logicDeleteFieldName}==$!{field.name}) |
||||||
|
@TableLogic |
||||||
|
#end |
||||||
|
private $!{field.propertyType} $!{field.propertyName}; |
||||||
|
|
||||||
|
#end |
||||||
|
## ---------- END 字段循环遍历 ---------- |
||||||
|
|
||||||
|
#if(!$!{entityLombokModel}) |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
#if($!{field.propertyType.equals("boolean")}) |
||||||
|
#set($getprefix="is") |
||||||
|
#else |
||||||
|
#set($getprefix="get") |
||||||
|
#end |
||||||
|
|
||||||
|
public $!{field.propertyType} $!{getprefix}$!{field.capitalName}() { |
||||||
|
return $!{field.propertyName}; |
||||||
|
} |
||||||
|
|
||||||
|
#if($!{entityBuilderModel}) |
||||||
|
public $!{entity} set$!{field.capitalName}($!{field.propertyType} $!{field.propertyName}) { |
||||||
|
#else |
||||||
|
public void set$!{field.capitalName}($!{field.propertyType} $!{field.propertyName}) { |
||||||
|
#end |
||||||
|
this.$!{field.propertyName} = $!{field.propertyName}; |
||||||
|
#if($!{entityBuilderModel}) |
||||||
|
return this; |
||||||
|
#end |
||||||
|
} |
||||||
|
#end |
||||||
|
#end |
||||||
|
|
||||||
|
#if($!{entityColumnConstant}) |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
public static final String $!{field.name.toUpperCase()} = "$!{field.name}"; |
||||||
|
|
||||||
|
#end |
||||||
|
#end |
||||||
|
#if($!{activeRecord}) |
||||||
|
@Override |
||||||
|
protected Serializable pkVal() { |
||||||
|
#if($!{keyPropertyName}) |
||||||
|
return this.$!{keyPropertyName}; |
||||||
|
#else |
||||||
|
return this.id; |
||||||
|
#end |
||||||
|
} |
||||||
|
|
||||||
|
#end |
||||||
|
#if(!$!{entityLombokModel}) |
||||||
|
@Override |
||||||
|
public String toString() { |
||||||
|
return "$!{entity}{" + |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
#if($!{velocityCount}==1) |
||||||
|
"$!{field.propertyName}=" + $!{field.propertyName} + |
||||||
|
#else |
||||||
|
", $!{field.propertyName}=" + $!{field.propertyName} + |
||||||
|
#end |
||||||
|
#end |
||||||
|
"}"; |
||||||
|
} |
||||||
|
#end |
||||||
|
} |
@ -0,0 +1,39 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
#set($dtoPackage=$package.Entity.replace("entity","dto")) |
||||||
|
package $!{dtoPackage}; |
||||||
|
|
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
import lombok.Data; |
||||||
|
import lombok.EqualsAndHashCode; |
||||||
|
#end |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment}数据传输对象实体类 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
@Data |
||||||
|
@EqualsAndHashCode(callSuper = true) |
||||||
|
#end |
||||||
|
public class $!{entity}DTO extends $!{entity} { |
||||||
|
private static final long serialVersionUID = 1L; |
||||||
|
|
||||||
|
} |
@ -0,0 +1,45 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
package $!{voPackage}; |
||||||
|
|
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
import lombok.Data; |
||||||
|
import lombok.EqualsAndHashCode; |
||||||
|
#end |
||||||
|
#if($!{swagger2}) |
||||||
|
import io.swagger.annotations.ApiModel; |
||||||
|
#end |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment}视图实体类 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
#if($!{entityLombokModel}) |
||||||
|
@Data |
||||||
|
@EqualsAndHashCode(callSuper = true) |
||||||
|
#end |
||||||
|
#if($!{swagger2}) |
||||||
|
@ApiModel(value = "$!{entity}VO对象", description = #if ("$!{table.comment}"=="")"$!{entity}VO对象"#else"$!{table.comment}"#end) |
||||||
|
#end |
||||||
|
public class $!{entity}VO extends $!{entity} { |
||||||
|
private static final long serialVersionUID = 1L; |
||||||
|
|
||||||
|
} |
@ -0,0 +1,47 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
package $!{package.Mapper}; |
||||||
|
|
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
import $!{voPackage}.$!{entity}VO; |
||||||
|
import $!{superMapperClassPackage}; |
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||||
|
import java.util.List; |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment} Mapper 接口 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
#if($!{kotlin}) |
||||||
|
interface $!{table.mapperName} : $!{superMapperClass}<$!{entity}> |
||||||
|
#else |
||||||
|
public interface $!{table.mapperName} extends $!{superMapperClass}<$!{entity}> { |
||||||
|
|
||||||
|
/** |
||||||
|
* 自定义分页 |
||||||
|
* |
||||||
|
* @param page |
||||||
|
* @param $!{table.entityPath} |
||||||
|
* @return |
||||||
|
*/ |
||||||
|
List<$!{entity}VO> select$!{entity}Page(IPage page, $!{entity}VO $!{table.entityPath}); |
||||||
|
|
||||||
|
} |
||||||
|
#end |
@ -0,0 +1,44 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
||||||
|
<mapper namespace="$!{package.Mapper}.$!{table.mapperName}"> |
||||||
|
|
||||||
|
#if($!{enableCache}) |
||||||
|
<!-- 开启二级缓存 --> |
||||||
|
<cache type="org.mybatis.caches.ehcache.LoggingEhcache"/> |
||||||
|
|
||||||
|
#end |
||||||
|
#if($!{baseResultMap}) |
||||||
|
<!-- 通用查询映射结果 --> |
||||||
|
<resultMap id="$!{table.entityPath}ResultMap" type="$!{package.Entity}.$!{entity}"> |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
#if($!{field.keyFlag})##生成主键排在第一位 |
||||||
|
<id column="$!{field.name}" property="$!{field.propertyName}"/> |
||||||
|
#end |
||||||
|
#end |
||||||
|
#foreach($field in $!{table.commonFields})##生成公共字段 |
||||||
|
<result column="$!{field.name}" property="$!{field.propertyName}"/> |
||||||
|
#end |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
#if(!$!{field.keyFlag})##生成普通字段 |
||||||
|
<result column="$!{field.name}" property="$!{field.propertyName}"/> |
||||||
|
#end |
||||||
|
#end |
||||||
|
</resultMap> |
||||||
|
|
||||||
|
#end |
||||||
|
#if($!{baseColumnList}) |
||||||
|
<!-- 通用查询结果列 --> |
||||||
|
<sql id="baseColumnList"> |
||||||
|
select |
||||||
|
#foreach($field in $!{table.commonFields}) |
||||||
|
#if($!{field.name} == $!{field.propertyName})$!{field.name}#else$!{field.name} AS $!{field.propertyName}#end, |
||||||
|
#end |
||||||
|
$!{table.fieldNames} |
||||||
|
</sql> |
||||||
|
|
||||||
|
<select id="select$!{entity}Page" resultMap="$!{table.entityPath}ResultMap"> |
||||||
|
select * from $!{table.name} where is_deleted = 0 |
||||||
|
</select> |
||||||
|
|
||||||
|
#end |
||||||
|
</mapper> |
@ -0,0 +1,5 @@ |
|||||||
|
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver |
||||||
|
spring.datasource.url=jdbc:mysql://localhost:3306/bladex?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&tinyInt1isBit=false&serverTimezone=GMT%2B8 |
||||||
|
spring.datasource.username=root |
||||||
|
spring.datasource.password=root |
||||||
|
author=BladeX |
@ -0,0 +1,50 @@ |
|||||||
|
import request from '@/router/axios'; |
||||||
|
|
||||||
|
export const getList = (current, size, params) => { |
||||||
|
return request({ |
||||||
|
url: '/api/$!{cfg.serviceName}/$!{table.entityPath}/list', |
||||||
|
method: 'get', |
||||||
|
params: { |
||||||
|
...params, |
||||||
|
current, |
||||||
|
size, |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
export const getDetail = (id) => { |
||||||
|
return request({ |
||||||
|
url: '/api/$!{cfg.serviceName}/$!{table.entityPath}/detail', |
||||||
|
method: 'get', |
||||||
|
params: { |
||||||
|
id |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
export const remove = (ids) => { |
||||||
|
return request({ |
||||||
|
url: '/api/$!{cfg.serviceName}/$!{table.entityPath}/remove', |
||||||
|
method: 'post', |
||||||
|
params: { |
||||||
|
ids, |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
export const add = (row) => { |
||||||
|
return request({ |
||||||
|
url: '/api/$!{cfg.serviceName}/$!{table.entityPath}/submit', |
||||||
|
method: 'post', |
||||||
|
data: row |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
export const update = (row) => { |
||||||
|
return request({ |
||||||
|
url: '/api/$!{cfg.serviceName}/$!{table.entityPath}/submit', |
||||||
|
method: 'post', |
||||||
|
data: row |
||||||
|
}) |
||||||
|
} |
||||||
|
|
@ -0,0 +1,174 @@ |
|||||||
|
<template> |
||||||
|
<basic-container> |
||||||
|
<avue-crud :option="option" |
||||||
|
:data="data" |
||||||
|
:page="page" |
||||||
|
@row-del="rowDel" |
||||||
|
v-model="form" |
||||||
|
:permission="permissionList" |
||||||
|
@row-update="rowUpdate" |
||||||
|
@row-save="rowSave" |
||||||
|
:before-open="beforeOpen" |
||||||
|
@search-change="searchChange" |
||||||
|
@search-reset="searchReset" |
||||||
|
@selection-change="selectionChange" |
||||||
|
@on-load="onLoad"> |
||||||
|
<template slot="menuLeft"> |
||||||
|
<el-button type="danger" |
||||||
|
size="small" |
||||||
|
icon="el-icon-delete" |
||||||
|
plain |
||||||
|
v-if="permission.$!{table.entityPath}_delete" |
||||||
|
@click="handleDelete">删 除 |
||||||
|
</el-button> |
||||||
|
</template> |
||||||
|
</avue-crud> |
||||||
|
</basic-container> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
import {getList, getDetail, add, update, remove} from "@/api/$!{servicePackage}/$!{table.entityPath}"; |
||||||
|
import {mapGetters} from "vuex"; |
||||||
|
|
||||||
|
export default { |
||||||
|
data() { |
||||||
|
return { |
||||||
|
form: {}, |
||||||
|
page: { |
||||||
|
pageSize: 10, |
||||||
|
currentPage: 1, |
||||||
|
total: 0 |
||||||
|
}, |
||||||
|
selectionList: [], |
||||||
|
option: { |
||||||
|
tip: false, |
||||||
|
border: true, |
||||||
|
index: true, |
||||||
|
viewBtn: true, |
||||||
|
selection: true, |
||||||
|
column: [ |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
{ |
||||||
|
label: "$!{field.comment}", |
||||||
|
prop: "$!{field.propertyName}", |
||||||
|
rules: [{ |
||||||
|
required: true, |
||||||
|
message: "请输入$!{field.comment}", |
||||||
|
trigger: "blur" |
||||||
|
}] |
||||||
|
}, |
||||||
|
#end |
||||||
|
] |
||||||
|
}, |
||||||
|
data: [] |
||||||
|
}; |
||||||
|
}, |
||||||
|
computed: { |
||||||
|
...mapGetters(["permission"]), |
||||||
|
permissionList() { |
||||||
|
return { |
||||||
|
addBtn: this.permission.$!{table.entityPath}_add, |
||||||
|
viewBtn: this.permission.$!{table.entityPath}_view, |
||||||
|
delBtn: this.permission.$!{table.entityPath}_delete, |
||||||
|
editBtn: this.permission.$!{table.entityPath}_edit |
||||||
|
}; |
||||||
|
}, |
||||||
|
ids() { |
||||||
|
let ids = []; |
||||||
|
this.selectionList.forEach(ele => { |
||||||
|
ids.push(ele.id); |
||||||
|
}); |
||||||
|
return ids.join(","); |
||||||
|
} |
||||||
|
}, |
||||||
|
methods: { |
||||||
|
rowSave(row, loading) { |
||||||
|
add(row).then(() => { |
||||||
|
loading(); |
||||||
|
this.onLoad(this.page); |
||||||
|
this.$message({ |
||||||
|
type: "success", |
||||||
|
message: "操作成功!" |
||||||
|
}); |
||||||
|
}); |
||||||
|
}, |
||||||
|
rowUpdate(row, index, loading) { |
||||||
|
update(row).then(() => { |
||||||
|
loading(); |
||||||
|
this.onLoad(this.page); |
||||||
|
this.$message({ |
||||||
|
type: "success", |
||||||
|
message: "操作成功!" |
||||||
|
}); |
||||||
|
}); |
||||||
|
}, |
||||||
|
rowDel(row) { |
||||||
|
this.$confirm("确定将选择数据删除?", { |
||||||
|
confirmButtonText: "确定", |
||||||
|
cancelButtonText: "取消", |
||||||
|
type: "warning" |
||||||
|
}) |
||||||
|
.then(() => { |
||||||
|
return remove(row.id); |
||||||
|
}) |
||||||
|
.then(() => { |
||||||
|
this.onLoad(this.page); |
||||||
|
this.$message({ |
||||||
|
type: "success", |
||||||
|
message: "操作成功!" |
||||||
|
}); |
||||||
|
}); |
||||||
|
}, |
||||||
|
searchReset() { |
||||||
|
this.onLoad(this.page); |
||||||
|
}, |
||||||
|
searchChange(params) { |
||||||
|
this.onLoad(this.page, params); |
||||||
|
}, |
||||||
|
selectionChange(list) { |
||||||
|
this.selectionList = list; |
||||||
|
}, |
||||||
|
handleDelete() { |
||||||
|
if (this.selectionList.length === 0) { |
||||||
|
this.$message.warning("请选择至少一条数据"); |
||||||
|
return; |
||||||
|
} |
||||||
|
this.$confirm("确定将选择数据删除?", { |
||||||
|
confirmButtonText: "确定", |
||||||
|
cancelButtonText: "取消", |
||||||
|
type: "warning" |
||||||
|
}) |
||||||
|
.then(() => { |
||||||
|
return remove(this.ids); |
||||||
|
}) |
||||||
|
.then(() => { |
||||||
|
this.onLoad(this.page); |
||||||
|
this.$message({ |
||||||
|
type: "success", |
||||||
|
message: "操作成功!" |
||||||
|
}); |
||||||
|
this.$refs.crud.toggleSelection(); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
beforeOpen(done, type) { |
||||||
|
if (["edit", "view"].includes(type)) { |
||||||
|
getDetail(this.form.id).then(res => { |
||||||
|
this.form = res.data.data; |
||||||
|
}); |
||||||
|
} |
||||||
|
done(); |
||||||
|
}, |
||||||
|
onLoad(page, params = {}) { |
||||||
|
getList(page.currentPage, page.pageSize, params).then(res => { |
||||||
|
const data = res.data.data; |
||||||
|
this.page.total = data.total; |
||||||
|
this.data = data.records; |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
</script> |
||||||
|
|
||||||
|
<style> |
||||||
|
</style> |
@ -0,0 +1,46 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
package $!{package.Service}; |
||||||
|
|
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
import $!{voPackage}.$!{entity}VO; |
||||||
|
import $!{superServiceClassPackage}; |
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment} 服务类 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
#if($!{kotlin}) |
||||||
|
interface $!{table.serviceName} : $!{superServiceClass}<$!{entity}> |
||||||
|
#else |
||||||
|
public interface $!{table.serviceName} extends $!{superServiceClass}<$!{entity}> { |
||||||
|
|
||||||
|
/** |
||||||
|
* 自定义分页 |
||||||
|
* |
||||||
|
* @param page |
||||||
|
* @param $!{table.entityPath} |
||||||
|
* @return |
||||||
|
*/ |
||||||
|
IPage<$!{entity}VO> select$!{entity}Page(IPage<$!{entity}VO> page, $!{entity}VO $!{table.entityPath}); |
||||||
|
|
||||||
|
} |
||||||
|
#end |
@ -0,0 +1,48 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
package $!{package.ServiceImpl}; |
||||||
|
|
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
import $!{voPackage}.$!{entity}VO; |
||||||
|
import $!{package.Mapper}.$!{table.mapperName}; |
||||||
|
import $!{package.Service}.$!{table.serviceName}; |
||||||
|
import $!{superServiceImplClassPackage}; |
||||||
|
import org.springframework.stereotype.Service; |
||||||
|
import com.baomidou.mybatisplus.core.metadata.IPage; |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment} 服务实现类 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
@Service |
||||||
|
#if($!{kotlin}) |
||||||
|
open class $!{table.serviceImplName} : $!{superServiceImplClass}<$!{table.mapperName}, $!{entity}>(), $!{table.serviceName} { |
||||||
|
|
||||||
|
} |
||||||
|
#else |
||||||
|
public class $!{table.serviceImplName} extends $!{superServiceImplClass}<$!{table.mapperName}, $!{entity}> implements $!{table.serviceName} { |
||||||
|
|
||||||
|
@Override |
||||||
|
public IPage<$!{entity}VO> select$!{entity}Page(IPage<$!{entity}VO> page, $!{entity}VO $!{table.entityPath}) { |
||||||
|
return page.setRecords(baseMapper.select$!{entity}Page(page, $!{table.entityPath})); |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
#end |
@ -0,0 +1,37 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
export const $!{upperEntityPath}_NAMESPACE = '$!{table.entityPath}'; |
||||||
|
|
||||||
|
export function $!{upperEntityPath}_LIST(payload) { |
||||||
|
return { |
||||||
|
type: `${$!{upperEntityPath}_NAMESPACE}/fetchList`, |
||||||
|
payload, |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
export function $!{upperEntityPath}_DETAIL(id) { |
||||||
|
return { |
||||||
|
type: `${$!{upperEntityPath}_NAMESPACE}/fetchDetail`, |
||||||
|
payload: { id }, |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
export function $!{upperEntityPath}_CLEAR_DETAIL() { |
||||||
|
return { |
||||||
|
type: `${$!{upperEntityPath}_NAMESPACE}/clearDetail`, |
||||||
|
payload: {}, |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
export function $!{upperEntityPath}_SUBMIT(payload) { |
||||||
|
return { |
||||||
|
type: `${$!{upperEntityPath}_NAMESPACE}/submit`, |
||||||
|
payload, |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
export function $!{upperEntityPath}_REMOVE(payload) { |
||||||
|
return { |
||||||
|
type: `${$!{upperEntityPath}_NAMESPACE}/remove`, |
||||||
|
payload, |
||||||
|
}; |
||||||
|
} |
@ -0,0 +1,73 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
import React, { PureComponent } from 'react'; |
||||||
|
import { Form, Input, Card, Button } from 'antd'; |
||||||
|
import { connect } from 'dva'; |
||||||
|
import Panel from '../../../components/Panel'; |
||||||
|
import styles from '../../../layouts/Sword.less'; |
||||||
|
import { $!{upperEntityPath}_SUBMIT } from '../../../actions/$!{table.entityPath}'; |
||||||
|
|
||||||
|
const FormItem = Form.Item; |
||||||
|
|
||||||
|
@connect(({ loading }) => ({ |
||||||
|
submitting: loading.effects['$!{table.entityPath}/submit'], |
||||||
|
})) |
||||||
|
@Form.create() |
||||||
|
class $!{entity}Add extends PureComponent { |
||||||
|
handleSubmit = e => { |
||||||
|
e.preventDefault(); |
||||||
|
const { dispatch, form } = this.props; |
||||||
|
form.validateFieldsAndScroll((err, values) => { |
||||||
|
if (!err) { |
||||||
|
dispatch($!{upperEntityPath}_SUBMIT(values)); |
||||||
|
} |
||||||
|
}); |
||||||
|
}; |
||||||
|
|
||||||
|
render() { |
||||||
|
const { |
||||||
|
form: { getFieldDecorator }, |
||||||
|
submitting, |
||||||
|
} = this.props; |
||||||
|
|
||||||
|
const formItemLayout = { |
||||||
|
labelCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 7 }, |
||||||
|
}, |
||||||
|
wrapperCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 12 }, |
||||||
|
md: { span: 10 }, |
||||||
|
}, |
||||||
|
}; |
||||||
|
|
||||||
|
const action = ( |
||||||
|
<Button type="primary" onClick={this.handleSubmit} loading={submitting}> |
||||||
|
提交 |
||||||
|
</Button> |
||||||
|
); |
||||||
|
|
||||||
|
return ( |
||||||
|
<Panel title="新增" back="/$!{cfg.servicePackage}/$!{table.entityPath}" action={action}> |
||||||
|
<Form hideRequiredMark style={{ marginTop: 8 }}> |
||||||
|
<Card className={styles.card} bordered={false}> |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
<FormItem {...formItemLayout} label="$!{field.comment}"> |
||||||
|
{getFieldDecorator('$!{field.propertyName}', { |
||||||
|
rules: [ |
||||||
|
{ |
||||||
|
required: true, |
||||||
|
message: '请输入$!{field.comment}', |
||||||
|
}, |
||||||
|
], |
||||||
|
})(<Input placeholder="请输入$!{field.comment}" />)} |
||||||
|
</FormItem> |
||||||
|
#end |
||||||
|
</Card> |
||||||
|
</Form> |
||||||
|
</Panel> |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
export default $!{entity}Add; |
@ -0,0 +1,97 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
import React, { PureComponent } from 'react'; |
||||||
|
import { Form, Input, Card, Button } from 'antd'; |
||||||
|
import { connect } from 'dva'; |
||||||
|
import Panel from '../../../components/Panel'; |
||||||
|
import styles from '../../../layouts/Sword.less'; |
||||||
|
import { $!{upperEntityPath}_DETAIL, $!{upperEntityPath}_SUBMIT } from '../../../actions/$!{table.entityPath}'; |
||||||
|
|
||||||
|
const FormItem = Form.Item; |
||||||
|
|
||||||
|
@connect(({ $!{table.entityPath}, loading }) => ({ |
||||||
|
$!{table.entityPath}, |
||||||
|
submitting: loading.effects['code/submit'], |
||||||
|
})) |
||||||
|
@Form.create() |
||||||
|
class $!{entity}Edit extends PureComponent { |
||||||
|
componentWillMount() { |
||||||
|
const { |
||||||
|
dispatch, |
||||||
|
match: { |
||||||
|
params: { id }, |
||||||
|
}, |
||||||
|
} = this.props; |
||||||
|
dispatch($!{upperEntityPath}_DETAIL(id)); |
||||||
|
} |
||||||
|
|
||||||
|
handleSubmit = e => { |
||||||
|
e.preventDefault(); |
||||||
|
const { |
||||||
|
dispatch, |
||||||
|
match: { |
||||||
|
params: { id }, |
||||||
|
}, |
||||||
|
form, |
||||||
|
} = this.props; |
||||||
|
form.validateFieldsAndScroll((err, values) => { |
||||||
|
if (!err) { |
||||||
|
const params = { |
||||||
|
id, |
||||||
|
...values, |
||||||
|
}; |
||||||
|
console.log(params); |
||||||
|
dispatch($!{upperEntityPath}_SUBMIT(params)); |
||||||
|
} |
||||||
|
}); |
||||||
|
}; |
||||||
|
|
||||||
|
render() { |
||||||
|
const { |
||||||
|
form: { getFieldDecorator }, |
||||||
|
$!{table.entityPath}: { detail }, |
||||||
|
submitting, |
||||||
|
} = this.props; |
||||||
|
|
||||||
|
const formItemLayout = { |
||||||
|
labelCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 7 }, |
||||||
|
}, |
||||||
|
wrapperCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 12 }, |
||||||
|
md: { span: 10 }, |
||||||
|
}, |
||||||
|
}; |
||||||
|
|
||||||
|
const action = ( |
||||||
|
<Button type="primary" onClick={this.handleSubmit} loading={submitting}> |
||||||
|
提交 |
||||||
|
</Button> |
||||||
|
); |
||||||
|
|
||||||
|
return ( |
||||||
|
<Panel title="修改" back="/$!{cfg.servicePackage}/$!{table.entityPath}" action={action}> |
||||||
|
<Form hideRequiredMark style={{ marginTop: 8 }}> |
||||||
|
<Card className={styles.card} bordered={false}> |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
<FormItem {...formItemLayout} label="$!{field.comment}"> |
||||||
|
{getFieldDecorator('$!{field.propertyName}', { |
||||||
|
rules: [ |
||||||
|
{ |
||||||
|
required: true, |
||||||
|
message: '请输入$!{field.comment}', |
||||||
|
}, |
||||||
|
], |
||||||
|
initialValue: detail.$!{field.propertyName}, |
||||||
|
})(<Input placeholder="请输入$!{field.comment}" />)} |
||||||
|
</FormItem> |
||||||
|
#end |
||||||
|
</Card> |
||||||
|
</Form> |
||||||
|
</Panel> |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
export default $!{entity}Edit; |
@ -0,0 +1,82 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
import React, { PureComponent } from 'react'; |
||||||
|
import { connect } from 'dva'; |
||||||
|
import { Button, Col, Form, Input, Row } from 'antd'; |
||||||
|
import Panel from '../../../components/Panel'; |
||||||
|
import { $!{upperEntityPath}_LIST } from '../../../actions/$!{table.entityPath}'; |
||||||
|
import Grid from '../../../components/Sword/Grid'; |
||||||
|
|
||||||
|
const FormItem = Form.Item; |
||||||
|
|
||||||
|
@connect(({ $!{table.entityPath}, loading }) => ({ |
||||||
|
$!{table.entityPath}, |
||||||
|
loading: loading.models.param, |
||||||
|
})) |
||||||
|
@Form.create() |
||||||
|
class $!{entity} extends PureComponent { |
||||||
|
// ============ 查询 =============== |
||||||
|
handleSearch = params => { |
||||||
|
const { dispatch } = this.props; |
||||||
|
dispatch($!{upperEntityPath}_LIST(params)); |
||||||
|
}; |
||||||
|
|
||||||
|
// ============ 查询表单 =============== |
||||||
|
renderSearchForm = onReset => { |
||||||
|
const { form } = this.props; |
||||||
|
const { getFieldDecorator } = form; |
||||||
|
|
||||||
|
return ( |
||||||
|
<Row gutter={{ md: 8, lg: 24, xl: 48 }}> |
||||||
|
<Col md={6} sm={24}> |
||||||
|
<FormItem label="查询名称"> |
||||||
|
{getFieldDecorator('name')(<Input placeholder="查询名称" />)} |
||||||
|
</FormItem> |
||||||
|
</Col> |
||||||
|
<Col> |
||||||
|
<div style={{ float: 'right' }}> |
||||||
|
<Button type="primary" htmlType="submit"> |
||||||
|
查询 |
||||||
|
</Button> |
||||||
|
<Button style={{ marginLeft: 8 }} onClick={onReset}> |
||||||
|
重置 |
||||||
|
</Button> |
||||||
|
</div> |
||||||
|
</Col> |
||||||
|
</Row> |
||||||
|
); |
||||||
|
}; |
||||||
|
|
||||||
|
render() { |
||||||
|
const code = '$!{table.entityPath}'; |
||||||
|
|
||||||
|
const { |
||||||
|
form, |
||||||
|
loading, |
||||||
|
$!{table.entityPath}: { data }, |
||||||
|
} = this.props; |
||||||
|
|
||||||
|
const columns = [ |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
{ |
||||||
|
title: '$!{field.comment}', |
||||||
|
dataIndex: '$!{field.propertyName}', |
||||||
|
}, |
||||||
|
#end |
||||||
|
]; |
||||||
|
|
||||||
|
return ( |
||||||
|
<Panel> |
||||||
|
<Grid |
||||||
|
code={code} |
||||||
|
form={form} |
||||||
|
onSearch={this.handleSearch} |
||||||
|
renderSearchForm={this.renderSearchForm} |
||||||
|
loading={loading} |
||||||
|
data={data} |
||||||
|
columns={columns} |
||||||
|
/> |
||||||
|
</Panel> |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
export default $!{entity}; |
@ -0,0 +1,84 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
import { message } from 'antd'; |
||||||
|
import router from 'umi/router'; |
||||||
|
import { $!{upperEntityPath}_NAMESPACE } from '../actions/$!{table.entityPath}'; |
||||||
|
import { list, submit, detail, remove } from '../services/$!{table.entityPath}'; |
||||||
|
|
||||||
|
export default { |
||||||
|
namespace: $!{upperEntityPath}_NAMESPACE, |
||||||
|
state: { |
||||||
|
data: { |
||||||
|
list: [], |
||||||
|
pagination: false, |
||||||
|
}, |
||||||
|
detail: {}, |
||||||
|
}, |
||||||
|
effects: { |
||||||
|
*fetchList({ payload }, { call, put }) { |
||||||
|
const response = yield call(list, payload); |
||||||
|
if (response.success) { |
||||||
|
yield put({ |
||||||
|
type: 'saveList', |
||||||
|
payload: { |
||||||
|
list: response.data, |
||||||
|
pagination: false, |
||||||
|
}, |
||||||
|
}); |
||||||
|
} |
||||||
|
}, |
||||||
|
*fetchDetail({ payload }, { call, put }) { |
||||||
|
const response = yield call(detail, payload); |
||||||
|
if (response.success) { |
||||||
|
yield put({ |
||||||
|
type: 'saveDetail', |
||||||
|
payload: { |
||||||
|
detail: response.data, |
||||||
|
}, |
||||||
|
}); |
||||||
|
} |
||||||
|
}, |
||||||
|
*clearDetail({ payload }, { put }) { |
||||||
|
yield put({ |
||||||
|
type: 'removeDetail', |
||||||
|
payload: { payload }, |
||||||
|
}); |
||||||
|
}, |
||||||
|
*submit({ payload }, { call }) { |
||||||
|
const response = yield call(submit, payload); |
||||||
|
if (response.success) { |
||||||
|
message.success('提交成功'); |
||||||
|
router.push('/$!{cfg.servicePackage}/$!{table.entityPath}'); |
||||||
|
} |
||||||
|
}, |
||||||
|
*remove({ payload }, { call }) { |
||||||
|
const { |
||||||
|
data: { keys }, |
||||||
|
success, |
||||||
|
} = payload; |
||||||
|
const response = yield call(remove, { ids: keys }); |
||||||
|
if (response.success) { |
||||||
|
success(); |
||||||
|
} |
||||||
|
}, |
||||||
|
}, |
||||||
|
reducers: { |
||||||
|
saveList(state, action) { |
||||||
|
return { |
||||||
|
...state, |
||||||
|
data: action.payload, |
||||||
|
}; |
||||||
|
}, |
||||||
|
saveDetail(state, action) { |
||||||
|
return { |
||||||
|
...state, |
||||||
|
detail: action.payload.detail, |
||||||
|
}; |
||||||
|
}, |
||||||
|
removeDetail(state) { |
||||||
|
return { |
||||||
|
...state, |
||||||
|
detail: {}, |
||||||
|
}; |
||||||
|
}, |
||||||
|
}, |
||||||
|
}; |
@ -0,0 +1,26 @@ |
|||||||
|
#set($params="$" + "{stringify" + "(params)" + "}") |
||||||
|
import { stringify } from 'qs'; |
||||||
|
import func from '../utils/Func'; |
||||||
|
import request from '../utils/request'; |
||||||
|
|
||||||
|
export async function list(params) { |
||||||
|
return request(`/api/$!{cfg.serviceName}/$!{table.entityPath}/list?$!{params}`); |
||||||
|
} |
||||||
|
|
||||||
|
export async function submit(params) { |
||||||
|
return request('/api/$!{cfg.serviceName}/$!{table.entityPath}/submit', { |
||||||
|
method: 'POST', |
||||||
|
body: params, |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
export async function detail(params) { |
||||||
|
return request(`/api/$!{cfg.serviceName}/$!{table.entityPath}/detail?$!{params}`); |
||||||
|
} |
||||||
|
|
||||||
|
export async function remove(params) { |
||||||
|
return request('/api/$!{cfg.serviceName}/$!{table.entityPath}/remove', { |
||||||
|
method: 'POST', |
||||||
|
body: func.toFormData(params), |
||||||
|
}); |
||||||
|
} |
@ -0,0 +1,74 @@ |
|||||||
|
#set($upperEntityPath=$table.entityPath.toUpperCase()) |
||||||
|
import React, { PureComponent } from 'react'; |
||||||
|
import router from 'umi/router'; |
||||||
|
import { Form, Card, Button } from 'antd'; |
||||||
|
import { connect } from 'dva'; |
||||||
|
import Panel from '../../../components/Panel'; |
||||||
|
import styles from '../../../layouts/Sword.less'; |
||||||
|
import { $!{upperEntityPath}_DETAIL } from '../../../actions/$!{table.entityPath}'; |
||||||
|
|
||||||
|
const FormItem = Form.Item; |
||||||
|
|
||||||
|
@connect(({ $!{table.entityPath} }) => ({ |
||||||
|
$!{table.entityPath}, |
||||||
|
})) |
||||||
|
@Form.create() |
||||||
|
class $!{entity}View extends PureComponent { |
||||||
|
componentWillMount() { |
||||||
|
const { |
||||||
|
dispatch, |
||||||
|
match: { |
||||||
|
params: { id }, |
||||||
|
}, |
||||||
|
} = this.props; |
||||||
|
dispatch($!{upperEntityPath}_DETAIL(id)); |
||||||
|
} |
||||||
|
|
||||||
|
handleEdit = () => { |
||||||
|
const { |
||||||
|
match: { |
||||||
|
params: { id }, |
||||||
|
}, |
||||||
|
} = this.props; |
||||||
|
router.push(`/$!{cfg.servicePackage}/$!{table.entityPath}/edit/$!{id}`); |
||||||
|
}; |
||||||
|
|
||||||
|
render() { |
||||||
|
const { |
||||||
|
$!{table.entityPath}: { detail }, |
||||||
|
} = this.props; |
||||||
|
|
||||||
|
const formItemLayout = { |
||||||
|
labelCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 7 }, |
||||||
|
}, |
||||||
|
wrapperCol: { |
||||||
|
xs: { span: 24 }, |
||||||
|
sm: { span: 12 }, |
||||||
|
md: { span: 10 }, |
||||||
|
}, |
||||||
|
}; |
||||||
|
|
||||||
|
const action = ( |
||||||
|
<Button type="primary" onClick={this.handleEdit}> |
||||||
|
修改 |
||||||
|
</Button> |
||||||
|
); |
||||||
|
|
||||||
|
return ( |
||||||
|
<Panel title="查看" back="/$!{cfg.servicePackage}/$!{table.entityPath}" action={action}> |
||||||
|
<Form hideRequiredMark style={{ marginTop: 8 }}> |
||||||
|
<Card className={styles.card} bordered={false}> |
||||||
|
#foreach($field in $!{table.fields}) |
||||||
|
<FormItem {...formItemLayout} label="$!{field.comment}"> |
||||||
|
<span>{detail.$!{field.propertyName}}</span> |
||||||
|
</FormItem> |
||||||
|
#end |
||||||
|
</Card> |
||||||
|
</Form> |
||||||
|
</Panel> |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
export default $!{entity}View; |
@ -0,0 +1,52 @@ |
|||||||
|
/* |
||||||
|
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved. |
||||||
|
* |
||||||
|
* Redistribution and use in source and binary forms, with or without |
||||||
|
* modification, are permitted provided that the following conditions are met: |
||||||
|
* |
||||||
|
* Redistributions of source code must retain the above copyright notice, |
||||||
|
* this list of conditions and the following disclaimer. |
||||||
|
* Redistributions in binary form must reproduce the above copyright |
||||||
|
* notice, this list of conditions and the following disclaimer in the |
||||||
|
* documentation and/or other materials provided with the distribution. |
||||||
|
* Neither the name of the dreamlu.net developer nor the names of its |
||||||
|
* contributors may be used to endorse or promote products derived from |
||||||
|
* this software without specific prior written permission. |
||||||
|
* Author: Chill 庄骞 (smallchill@163.com) |
||||||
|
*/ |
||||||
|
#set($wrapperPackage=$package.Entity.replace("entity","wrapper")) |
||||||
|
package $!{wrapperPackage}; |
||||||
|
|
||||||
|
import lombok.AllArgsConstructor; |
||||||
|
import org.springblade.core.mp.support.BaseEntityWrapper; |
||||||
|
import org.springblade.core.tool.utils.BeanUtil; |
||||||
|
import org.springblade.system.feign.IDictClient; |
||||||
|
import $!{package.Entity}.$!{entity}; |
||||||
|
#set($voPackage=$package.Entity.replace("entity","vo")) |
||||||
|
import $!{voPackage}.$!{entity}VO; |
||||||
|
|
||||||
|
/** |
||||||
|
* $!{table.comment}包装类,返回视图层所需的字段 |
||||||
|
* |
||||||
|
* @author $!{author} |
||||||
|
* @since $!{date} |
||||||
|
*/ |
||||||
|
@AllArgsConstructor |
||||||
|
public class $!{entity}Wrapper extends BaseEntityWrapper<$!{entity}, $!{entity}VO> { |
||||||
|
|
||||||
|
private IDictClient dictClient; |
||||||
|
|
||||||
|
@Override |
||||||
|
public $!{entity}VO entityVO($!{entity} $!{table.entityPath}) { |
||||||
|
$!{entity}VO $!{table.entityPath}VO = BeanUtil.copy($!{table.entityPath}, $!{entity}VO.class); |
||||||
|
|
||||||
|
/*R<String> dict = dictClient.getValue("$!{table.entityPath}" , $!{table.entityPath}VO.getCategory()); |
||||||
|
if (dict.isSuccess()) { |
||||||
|
String categoryName = dict.getData(); |
||||||
|
$!{table.entityPath}VO.setCategoryName(categoryName); |
||||||
|
}*/ |
||||||
|
|
||||||
|
return $!{table.entityPath}VO; |
||||||
|
} |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue