评估内容部分代码

This commit is contained in:
sk1551
2020-10-17 18:58:24 +08:00
parent d2b50c0d72
commit 47369fc805
8 changed files with 252 additions and 69 deletions

View File

@ -4,6 +4,7 @@ import java.io.Serializable;
import java.util.List;
import java.util.stream.Collectors;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.ruoyi.project.benyi.domain.ByAssessmentcontent;
import com.ruoyi.project.benyi.domain.ByDayFlowDetail;
import com.ruoyi.project.benyi.domain.ByMath;
import com.ruoyi.project.benyi.domain.ByTheme;
@ -37,6 +38,13 @@ public class TreeSelect implements Serializable
this.children = dept.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
}
public TreeSelect(ByAssessmentcontent byAssessmentcontent)
{
this.id = byAssessmentcontent.getId();
this.label = byAssessmentcontent.getName();
this.children = byAssessmentcontent.getChildren().stream().map(TreeSelect::new).collect(Collectors.toList());
}
public TreeSelect(SysMenu menu)
{
this.id = menu.getMenuId();

View File

@ -1,6 +1,10 @@
package com.ruoyi.project.benyi.controller;
import java.util.List;
import com.ruoyi.common.utils.ServletUtils;
import com.ruoyi.framework.security.LoginUser;
import com.ruoyi.framework.security.service.TokenService;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
@ -32,6 +36,8 @@ public class ByAssessmentcontentController extends BaseController
{
@Autowired
private IByAssessmentcontentService byAssessmentcontentService;
@Autowired
private TokenService tokenService;
/**
* 查询评估内容列表
@ -68,6 +74,18 @@ public class ByAssessmentcontentController extends BaseController
return AjaxResult.success(byAssessmentcontentService.selectByAssessmentcontentById(id));
}
/**
* 获取部门下拉树列表
*/
@GetMapping("/treeselect")
public AjaxResult treeselect(ByAssessmentcontent byAssessmentcontent) {
List<ByAssessmentcontent> byAssessmentcontents = byAssessmentcontentService.selectByAssessmentcontentList(byAssessmentcontent);
return AjaxResult.success(byAssessmentcontentService.buildByAssessmentcontentTreeSelect(byAssessmentcontents));
}
/**
* 新增评估内容
*/

View File

@ -5,6 +5,9 @@ import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.framework.aspectj.lang.annotation.Excel;
import com.ruoyi.framework.web.domain.BaseEntity;
import java.util.ArrayList;
import java.util.List;
/**
* 评估内容对象 by_assessmentcontent
*
@ -23,7 +26,7 @@ public class ByAssessmentcontent extends BaseEntity {
* 父id
*/
@Excel(name = "父id")
private Long parentid;
private Long parentId;
/**
* 名称
@ -37,6 +40,28 @@ public class ByAssessmentcontent extends BaseEntity {
@Excel(name = "是否元素")
private String iselement;
public String getParentName() {
return parentName;
}
public void setParentName(String parentName) {
this.parentName = parentName;
}
public List<ByAssessmentcontent> getChildren() {
return children;
}
public void setChildren(List<ByAssessmentcontent> children) {
this.children = children;
}
/** 父部门名称 */
private String parentName;
/** 子部门 */
private List<ByAssessmentcontent> children = new ArrayList<ByAssessmentcontent>();
/**
* 元素才有适用范围;应该以幼儿的岁数为准
*/
@ -51,14 +76,6 @@ public class ByAssessmentcontent extends BaseEntity {
return id;
}
public void setParentid(Long parentid) {
this.parentid = parentid;
}
public Long getParentid() {
return parentid;
}
public void setName(String name) {
this.name = name;
}
@ -87,11 +104,19 @@ public class ByAssessmentcontent extends BaseEntity {
public String toString() {
return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE)
.append("id", getId())
.append("parentid", getParentid())
.append("parentId", getParentId())
.append("name", getName())
.append("iselement", getIselement())
.append("scope", getScope())
.append("createTime", getCreateTime())
.toString();
}
public Long getParentId() {
return parentId;
}
public void setParentId(Long parentId) {
this.parentId = parentId;
}
}

View File

@ -2,6 +2,7 @@ package com.ruoyi.project.benyi.service;
import java.util.List;
import com.ruoyi.framework.web.domain.TreeSelect;
import com.ruoyi.project.benyi.domain.ByAssessmentcontent;
/**
@ -27,6 +28,22 @@ public interface IByAssessmentcontentService {
*/
public List<ByAssessmentcontent> selectByAssessmentcontentList(ByAssessmentcontent byAssessmentcontent);
/**
* 构建前端所需要树结构
*
* @param byAssessmentcontents 部门列表
* @return 树结构列表
*/
List<ByAssessmentcontent> buildbyAssessmentcontentTree(List<ByAssessmentcontent> byAssessmentcontents);
/**
* 构建前端所需要下拉树结构
*
* @param byAssessmentcontents 部门列表
* @return 下拉树结构列表
*/
public List<TreeSelect> buildByAssessmentcontentTreeSelect(List<ByAssessmentcontent> byAssessmentcontents);
/**
* 新增评估内容
*

View File

@ -1,8 +1,13 @@
package com.ruoyi.project.benyi.service.impl;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.stream.Collectors;
import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.framework.web.domain.TreeSelect;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.ruoyi.project.benyi.mapper.ByAssessmentcontentMapper;
@ -42,6 +47,44 @@ public class ByAssessmentcontentServiceImpl implements IByAssessmentcontentServi
return byAssessmentcontentMapper.selectByAssessmentcontentList(byAssessmentcontent);
}
/**
* 构建前端所需要树结构
*
* @param byAssessmentcontents 部门列表
* @return 树结构列表
*/
@Override
public List<ByAssessmentcontent> buildbyAssessmentcontentTree(List<ByAssessmentcontent> byAssessmentcontents)
{
List<ByAssessmentcontent> returnList = new ArrayList<ByAssessmentcontent>();
List<Long> tempList = new ArrayList<Long>();
for (ByAssessmentcontent byAssessmentcontent : byAssessmentcontents)
{
tempList.add(byAssessmentcontent.getId());
}
for (Iterator<ByAssessmentcontent> iterator = byAssessmentcontents.iterator(); iterator.hasNext();)
{
ByAssessmentcontent byAssessmentcontent = (ByAssessmentcontent) iterator.next();
// 如果是顶级节点, 遍历该父节点的所有子节点
if (!tempList.contains(byAssessmentcontent.getParentId()))
{
recursionFn(byAssessmentcontents, byAssessmentcontent);
returnList.add(byAssessmentcontent);
}
}
if (returnList.isEmpty())
{
returnList = byAssessmentcontents;
}
return returnList;
}
@Override
public List<TreeSelect> buildByAssessmentcontentTreeSelect(List<ByAssessmentcontent> byAssessmentcontents) {
List<ByAssessmentcontent> byAssessmentcontentTrees = buildbyAssessmentcontentTree(byAssessmentcontents);
return byAssessmentcontentTrees.stream().map(TreeSelect::new).collect(Collectors.toList());
}
/**
* 新增评估内容
*
@ -86,4 +129,54 @@ public class ByAssessmentcontentServiceImpl implements IByAssessmentcontentServi
public int deleteByAssessmentcontentById(Long id) {
return byAssessmentcontentMapper.deleteByAssessmentcontentById(id);
}
/**
* 递归列表
*/
private void recursionFn(List<ByAssessmentcontent> list, ByAssessmentcontent t)
{
// 得到子节点列表
List<ByAssessmentcontent> childList = getChildList(list, t);
t.setChildren(childList);
for (ByAssessmentcontent tChild : childList)
{
if (hasChild(list, tChild))
{
// 判断是否有子节点
Iterator<ByAssessmentcontent> it = childList.iterator();
while (it.hasNext())
{
ByAssessmentcontent n = (ByAssessmentcontent) it.next();
recursionFn(list, n);
}
}
}
}
/**
* 得到子节点列表
*/
private List<ByAssessmentcontent> getChildList(List<ByAssessmentcontent> list, ByAssessmentcontent t)
{
List<ByAssessmentcontent> tlist = new ArrayList<ByAssessmentcontent>();
Iterator<ByAssessmentcontent> it = list.iterator();
while (it.hasNext())
{
ByAssessmentcontent n = (ByAssessmentcontent) it.next();
if (StringUtils.isNotNull(n.getParentId()) && n.getParentId().longValue() == t.getId().longValue())
{
tlist.add(n);
}
}
return tlist;
}
/**
* 判断是否有子节点
*/
private boolean hasChild(List<ByAssessmentcontent> list, ByAssessmentcontent t)
{
return getChildList(list, t).size() > 0 ? true : false;
}
}

View File

@ -6,7 +6,7 @@
<resultMap type="ByAssessmentcontent" id="ByAssessmentcontentResult">
<result property="id" column="id"/>
<result property="parentid" column="parentId"/>
<result property="parentId" column="parentId"/>
<result property="name" column="name"/>
<result property="iselement" column="iselement"/>
<result property="scope" column="scope"/>
@ -21,7 +21,7 @@
resultMap="ByAssessmentcontentResult">
<include refid="selectByAssessmentcontentVo"/>
<where>
<if test="parentid != null ">and parentId = #{parentid}</if>
<if test="parentId != null ">and parentId = #{parentId}</if>
<if test="name != null and name != ''">and name like concat('%', #{name}, '%')</if>
<if test="iselement != null and iselement != ''">and iselement = #{iselement}</if>
<if test="scope != null and scope != ''">and scope = #{scope}</if>
@ -36,14 +36,14 @@
<insert id="insertByAssessmentcontent" parameterType="ByAssessmentcontent" useGeneratedKeys="true" keyProperty="id">
insert into by_assessmentcontent
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="parentid != null ">parentId,</if>
<if test="parentId != null ">parentId,</if>
<if test="name != null and name != ''">name,</if>
<if test="iselement != null and iselement != ''">iselement,</if>
<if test="scope != null and scope != ''">scope,</if>
<if test="createTime != null ">create_time,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="parentid != null ">#{parentid},</if>
<if test="parentId != null ">#{parentId},</if>
<if test="name != null and name != ''">#{name},</if>
<if test="iselement != null and iselement != ''">#{iselement},</if>
<if test="scope != null and scope != ''">#{scope},</if>
@ -54,7 +54,7 @@
<update id="updateByAssessmentcontent" parameterType="ByAssessmentcontent">
update by_assessmentcontent
<trim prefix="SET" suffixOverrides=",">
<if test="parentid != null ">parentId = #{parentid},</if>
<if test="parentId != null ">parentId = #{parentId},</if>
<if test="name != null and name != ''">name = #{name},</if>
<if test="iselement != null and iselement != ''">iselement = #{iselement},</if>
<if test="scope != null and scope != ''">scope = #{scope},</if>