公司/分部 列表接口

pull/9/MERGE
dxfeng 3 years ago
parent b2fd60a9bc
commit 5e8041348a

@ -1,13 +1,11 @@
package com.engine.organization.entity.comp.bo; package com.engine.organization.entity.comp.bo;
import com.engine.organization.entity.comp.dto.CompListDTO; import com.engine.organization.entity.comp.dto.CompListDTO;
import com.engine.organization.entity.comp.param.CompSearchParam;
import com.engine.organization.entity.comp.po.CompPO; import com.engine.organization.entity.comp.po.CompPO;
import org.apache.commons.collections.CollectionUtils; import org.apache.commons.collections.CollectionUtils;
import java.util.Collection; import java.util.*;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@ -30,7 +28,6 @@ public class CompBO {
.orgCode(e.getOrgCode()) .orgCode(e.getOrgCode())
.industry(e.getIndustry()) .industry(e.getIndustry())
.compPrincipal(e.getCompPrincipal()) .compPrincipal(e.getCompPrincipal())
.description(e.getDescription())
.forbiddenTag(e.getForbiddenTag()) .forbiddenTag(e.getForbiddenTag())
.build() .build()
).collect(Collectors.toList()); ).collect(Collectors.toList());
@ -41,4 +38,28 @@ public class CompBO {
}).collect(Collectors.toList()); }).collect(Collectors.toList());
} }
public static CompPO convertParamToPO(CompSearchParam param, Long employeeId) {
if (null == param) {
return null;
}
return CompPO.builder()
.id(param.getId() == null ? 0 : param.getId())
.compNo(param.getCompNo())
.compName(param.getCompName())
.compNameShort(param.getCompNameShort())
.parentCompany(param.getParentCompany())
.orgCode(param.getOrgCode())
.industry(param.getIndustry())
.compPrincipal(param.getCompPrincipal())
.description(param.getDescription())
.forbiddenTag(param.getForbiddenTag() == null ? null : param.getForbiddenTag() ? 0 : 1)
.deleteType(0)
.createTime(new Date())
.updateTime(new Date())
.creator(employeeId)
.build();
}
} }

@ -78,17 +78,11 @@ public class CompListDTO {
@TableTitle(title = "负责人", dataIndex = "compPrincipal", key = "compPrincipal") @TableTitle(title = "负责人", dataIndex = "compPrincipal", key = "compPrincipal")
private Integer compPrincipal; private Integer compPrincipal;
/**
*
*/
@TableTitle(title = "说明", dataIndex = "description", key = "description")
private String description;
/** /**
* *
*/ */
@TableTitle(title = "禁用标记", dataIndex = "forbiddenTag", key = "forbiddenTag") @TableTitle(title = "禁用标记", dataIndex = "forbiddenTag", key = "forbiddenTag")
private String forbiddenTag; private int forbiddenTag;
/** /**
* *

@ -0,0 +1,70 @@
package com.engine.organization.entity.comp.param;
import com.engine.organization.common.BaseQueryParam;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* @description: TODO
* @author:dxfeng
* @createTime: 2022/05/16
* @version: 1.0
*/
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class CompSearchParam extends BaseQueryParam {
/**
*
*/
private Long id;
/**
*
*/
private String compNo;
/**
*
*/
private String compName;
/**
*
*/
private String compNameShort;
/**
*
*/
private Long parentCompany;
/**
*
*/
private String orgCode;
/**
*
*/
private Integer industry;
/**
*
*/
private Integer compPrincipal;
/**
*
*/
private String description;
/**
*
*/
private Boolean forbiddenTag;
}

@ -18,16 +18,57 @@ import java.util.Date;
@AllArgsConstructor @AllArgsConstructor
@NoArgsConstructor @NoArgsConstructor
public class CompPO { public class CompPO {
/**
*
*/
private Long id; private Long id;
/**
*
*/
private String compNo; private String compNo;
/**
*
*/
private String compName; private String compName;
/**
*
*/
private String compNameShort; private String compNameShort;
/**
*
*/
private Long parentCompany; private Long parentCompany;
/**
*
*/
private String orgCode; private String orgCode;
/**
*
*/
private Integer industry; private Integer industry;
/**
*
*/
private Integer compPrincipal; private Integer compPrincipal;
/**
*
*/
private String description; private String description;
private String forbiddenTag;
/**
*
*/
private Integer forbiddenTag;
private Long creator; private Long creator;
private int deleteType; private int deleteType;
private Date createTime; private Date createTime;

@ -1,9 +1,9 @@
package com.engine.organization.mapper.comp; package com.engine.organization.mapper.comp;
import com.engine.organization.common.BaseQueryParam;
import com.engine.organization.entity.comp.po.CompPO; import com.engine.organization.entity.comp.po.CompPO;
import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Param;
import java.util.Collection;
import java.util.List; import java.util.List;
/** /**
@ -15,8 +15,30 @@ import java.util.List;
public interface CompMapper { public interface CompMapper {
/** /**
* *
* @param queryParam * @param compPO
* @return * @return
*/ */
List<CompPO> list(@Param("param") BaseQueryParam queryParam); List<CompPO> list(CompPO compPO);
/**
* No
*
* @param compNo
* @return
*/
List<CompPO> listByNo(@Param("compNo") String compNo);
/**
*
*
* @param compPO
* @return
*/
int updateForbiddenTagById(CompPO compPO);
/**
*
*
* @param ids
*/
int deleteByIds(@Param("ids") Collection<Long> ids);
} }

@ -38,13 +38,92 @@
, t.update_time , t.update_time
</sql> </sql>
<select id="list" resultMap="BaseResultMap"> <sql id="paramSql">
<if test="compNo != null and compNo !='' ">
and comp_no like CONCAT('%',#{compNo},'%')
</if>
<if test="compName != null and compName !='' ">
and comp_name like CONCAT('%',#{compName},'%')
</if>
<if test="compNameShort != null and compNameShort !='' ">
and comp_name_short like CONCAT('%',#{compNameShort},'%')
</if>
<if test="orgCode != null and orgCode !='' ">
and org_code like CONCAT('%',#{orgCode},'%')
</if>
</sql>
<!-- <sql id="paramSql" databaseId="oracle">-->
<!-- <if test="compNo != null and compNo !='' ">-->
<!-- and comp_no like '%'||#{compNo}||'%'-->
<!-- </if>-->
<!-- <if test="compName != null and compName !='' ">-->
<!-- and comp_name like '%'||#{compName}||'%'-->
<!-- </if>-->
<!-- <if test="compNameShort != null and compNameShort !='' ">-->
<!-- and comp_name_short like '%'||#{compNameShort}||'%'-->
<!-- </if>-->
<!-- <if test="orgCode != null and orgCode !='' ">-->
<!-- and org_code like '%'||#{orgCode}||'%'-->
<!-- </if>-->
<!-- </sql>-->
<!-- <sql id="paramSql" databaseId="sqlserver">-->
<!-- <if test="compNo != null and compNo !='' ">-->
<!-- and comp_no like '%'+#{compNo}+'%'-->
<!-- </if>-->
<!-- <if test="compName != null and compName !='' ">-->
<!-- and comp_name like '%'+#{compName}+'%'-->
<!-- </if>-->
<!-- <if test="compNameShort != null and compNameShort !='' ">-->
<!-- and comp_name_short like '%'+#{compNameShort}+'%'-->
<!-- </if>-->
<!-- <if test="orgCode != null and orgCode !='' ">-->
<!-- and org_code like '%'+#{orgCode}+'%'-->
<!-- </if>-->
<!-- </sql>-->
<select id="list" resultMap="BaseResultMap" parameterType="com.engine.organization.entity.comp.po.CompPO">
SELECT SELECT
<include refid="baseColumns"/> <include refid="baseColumns"/>
FROM FROM
jcl_org_comp t jcl_org_comp t
WHERE t.delete_type = 0 WHERE t.delete_type = 0
<if test="parentCompany != null and parentCompany !='' ">
and parent_company = #{parentCompany}
</if>
<if test="compPrincipal != null and compPrincipal !='' ">
and comp_principal = #{compPrincipal}
</if>
<if test="industry != null and industry !='' ">
and industry = #{industry}
</if>
<if test="forbiddenTag != null and forbiddenTag !='' ">
and forbidden_tag = #{forbiddenTag}
</if>
<include refid="paramSql"/>
</select>
<select id="listByNo" parameterType="com.engine.organization.entity.comp.po.CompPO" resultMap="BaseResultMap">
select
<include refid="baseColumns"/>
from jcl_org_comp t where comp_no = #{compNo} AND delete_type = 0
</select> </select>
<update id="updateForbiddenTagById" parameterType="com.engine.organization.entity.sequence.po.SequencePO">
update jcl_org_comp
<set>
forbidden_tag=#{forbiddenTag},
</set>
WHERE id = #{id} AND delete_type = 0
</update>
<update id="deleteByIds">
UPDATE jcl_org_comp
SET delete_type = 1
WHERE delete_type = 0
AND id IN
<foreach collection="ids" open="(" item="id" separator="," close=")">
#{id}
</foreach>
</update>
</mapper> </mapper>

@ -1,7 +1,8 @@
package com.engine.organization.service; package com.engine.organization.service;
import com.engine.organization.common.BaseQueryParam; import com.engine.organization.entity.comp.param.CompSearchParam;
import java.util.Collection;
import java.util.Map; import java.util.Map;
/** /**
@ -14,8 +15,37 @@ public interface CompService {
/** /**
* *
* @param baseQueryParam * @param params
* @return * @return
*/ */
Map<String,Object> listPage(BaseQueryParam baseQueryParam); Map<String,Object> listPage(CompSearchParam params);
/**
*
*
* @param params
*/
int updateForbiddenTagById(CompSearchParam params);
/**
* ID
*
* @param ids
*/
int deleteByIds(Collection<Long> ids);
/**
*
*
* @param params
* @return
*/
Map<String, Object> getSearchCondition(Map<String, Object> params);
/**
*
* @return
*/
Map<String, Object> getHasRight();
} }

@ -1,25 +1,28 @@
package com.engine.organization.service.impl; package com.engine.organization.service.impl;
import com.api.browser.bean.SearchConditionGroup;
import com.api.browser.bean.SearchConditionItem;
import com.api.browser.bean.SearchConditionOption;
import com.cloudstore.eccom.pc.table.WeaTableColumn; import com.cloudstore.eccom.pc.table.WeaTableColumn;
import com.cloudstore.eccom.result.WeaResultMsg; import com.cloudstore.eccom.result.WeaResultMsg;
import com.engine.core.impl.Service; import com.engine.core.impl.Service;
import com.engine.organization.common.BaseQueryParam;
import com.engine.organization.component.OrganizationWeaTable; import com.engine.organization.component.OrganizationWeaTable;
import com.engine.organization.entity.comp.bo.CompBO; import com.engine.organization.entity.comp.bo.CompBO;
import com.engine.organization.entity.comp.dto.CompListDTO; import com.engine.organization.entity.comp.dto.CompListDTO;
import com.engine.organization.entity.comp.param.CompSearchParam;
import com.engine.organization.entity.comp.po.CompPO; import com.engine.organization.entity.comp.po.CompPO;
import com.engine.organization.mapper.comp.CompMapper; import com.engine.organization.mapper.comp.CompMapper;
import com.engine.organization.service.CompService; import com.engine.organization.service.CompService;
import com.engine.organization.util.MenuBtn;
import com.engine.organization.util.OrganizationAssert;
import com.engine.organization.util.OrganizationFormItemUtil;
import com.engine.organization.util.db.MapperProxyFactory; import com.engine.organization.util.db.MapperProxyFactory;
import com.engine.organization.util.page.Column; import com.engine.organization.util.page.Column;
import com.engine.organization.util.page.PageInfo; import com.engine.organization.util.page.PageInfo;
import com.engine.organization.util.page.PageUtil; import com.engine.organization.util.page.PageUtil;
import java.util.Collection; import java.util.*;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@ -34,18 +37,19 @@ public class CompServiceImpl extends Service implements CompService {
} }
@Override @Override
public Map<String, Object> listPage(BaseQueryParam queryParam) { public Map<String, Object> listPage(CompSearchParam params) {
Map<String,Object> datas = new HashMap<>(); Map<String,Object> datas = new HashMap<>();
PageUtil.start(queryParam.getCurrent(), queryParam.getPageSize()); PageUtil.start(params.getCurrent(), params.getPageSize());
List<CompPO> list = getCompMapper().list(queryParam); List<CompPO> list = getCompMapper().list(CompBO.convertParamToPO(params,(long) user.getUID()));
PageInfo<CompPO> pageInfo = new PageInfo<>(list, CompPO.class); PageInfo<CompPO> pageInfo = new PageInfo<>(list, CompPO.class);
Collection<CompPO> compPOS = pageInfo.getList(); Collection<CompPO> compPOS = pageInfo.getList();
//
List<CompListDTO> compListDTOS = CompBO.buildCompDTOList(compPOS); List<CompListDTO> compListDTOS = CompBO.buildCompDTOList(compPOS);
PageInfo<CompListDTO> pageInfos = new PageInfo<>(compListDTOS, CompListDTO.class); PageInfo<CompListDTO> pageInfos = new PageInfo<>(compListDTOS, CompListDTO.class);
pageInfos.setTotal(pageInfo.getTotal()); pageInfos.setTotal(pageInfo.getTotal());
pageInfos.setPageNum(queryParam.getCurrent()); pageInfos.setPageNum(params.getCurrent());
pageInfos.setPageSize(queryParam.getPageSize()); pageInfos.setPageSize(params.getPageSize());
OrganizationWeaTable<CompListDTO> table = new OrganizationWeaTable<>(user, CompListDTO.class); OrganizationWeaTable<CompListDTO> table = new OrganizationWeaTable<>(user, CompListDTO.class);
List<Column> columns = pageInfos.getColumns(); List<Column> columns = pageInfos.getColumns();
@ -62,4 +66,63 @@ public class CompServiceImpl extends Service implements CompService {
datas.put("dataKey",result.getResultMap()); datas.put("dataKey",result.getResultMap());
return datas; return datas;
} }
@Override
public int updateForbiddenTagById(CompSearchParam params) {
CompPO compPO = CompPO.builder().id(params.getId()).forbiddenTag(params.getForbiddenTag() ? 0 : 1).build();
return getCompMapper().updateForbiddenTagById(compPO);
}
@Override
public int deleteByIds(Collection<Long> ids) {
OrganizationAssert.notEmpty(ids, "请选择要删除的数据");
return getCompMapper().deleteByIds(ids);
}
@Override
public Map<String, Object> getSearchCondition(Map<String, Object> params) {
Map<String, Object> apiDatas = new HashMap<>();
List<SearchConditionGroup> addGroups = new ArrayList<>();
List<SearchConditionItem> conditionItems = new ArrayList<>();
// 编号
SearchConditionItem compNoItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "编号", "compNo");
// 名称
SearchConditionItem compNameItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "名称", "compName");
// 简称
SearchConditionItem compNameShortItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "简称", "compNameShort");
// TODO
// 上级公司
SearchConditionItem compBrowserItem = OrganizationFormItemUtil.browserItem(user, 2, 16, 2, false, "上级公司", "161", "parentCompany", "compBrowser");
// 组织机构代码
SearchConditionItem orgCodeItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "组织机构代码", "orgCode");
// 行业
SearchConditionItem industryItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "行业", "industry");
// 负责人
SearchConditionItem compPrincipalItem = OrganizationFormItemUtil.inputItem(user, 2, 16, 2, 50, "负责人", "compPrincipal");
// 禁用标记
List<SearchConditionOption> selectOptions = new ArrayList<>();
SearchConditionOption enableOption = new SearchConditionOption("0","启用");
SearchConditionOption disableOption = new SearchConditionOption("1","禁用");
selectOptions.add(enableOption);
selectOptions.add(disableOption);
SearchConditionItem forbiddenTagItem= OrganizationFormItemUtil.selectItem(user,selectOptions,2,16,6,false,"禁用标记","forbiddenTag");
conditionItems.add(compNoItem);
conditionItems.add(compNameItem);
conditionItems.add(compNameShortItem);
conditionItems.add(compBrowserItem);
conditionItems.add(orgCodeItem);
conditionItems.add(industryItem);
conditionItems.add(compPrincipalItem);
conditionItems.add(forbiddenTagItem);
addGroups.add(new SearchConditionGroup("高级搜索条件", true, conditionItems));
apiDatas.put("conditions", addGroups);
return apiDatas;
}
@Override
public Map<String, Object> getHasRight() {
return MenuBtn.getCommonBtnDatas();
}
} }

@ -1,7 +1,7 @@
package com.engine.organization.web; package com.engine.organization.web;
import com.engine.common.util.ServiceUtil; import com.engine.common.util.ServiceUtil;
import com.engine.organization.common.BaseQueryParam; import com.engine.organization.entity.comp.param.CompSearchParam;
import com.engine.organization.util.response.ReturnResult; import com.engine.organization.util.response.ReturnResult;
import com.engine.organization.wrapper.CompWrapper; import com.engine.organization.wrapper.CompWrapper;
import io.swagger.v3.oas.annotations.parameters.RequestBody; import io.swagger.v3.oas.annotations.parameters.RequestBody;
@ -32,15 +32,16 @@ public class CompController {
* *
* @param request * @param request
* @param response * @param response
* @param params
* @return * @return
*/ */
@POST @POST
@Path("/listComp") @Path("/listComp")
@Produces(MediaType.APPLICATION_JSON) @Produces(MediaType.APPLICATION_JSON)
public ReturnResult listComp(@Context HttpServletRequest request, @Context HttpServletResponse response, @RequestBody BaseQueryParam queryParam) { public ReturnResult listComp(@Context HttpServletRequest request, @Context HttpServletResponse response, @RequestBody CompSearchParam params) {
try { try {
User user = HrmUserVarify.getUser(request, response); User user = HrmUserVarify.getUser(request, response);
return ReturnResult.successed(getCompWrapper(user).listPage(queryParam)); return ReturnResult.successed(getCompWrapper(user).listPage(params));
} catch (Exception e) { } catch (Exception e) {
return ReturnResult.exceptionHandle(e.getMessage()); return ReturnResult.exceptionHandle(e.getMessage());
} }

@ -2,7 +2,7 @@ package com.engine.organization.wrapper;
import com.engine.common.util.ServiceUtil; import com.engine.common.util.ServiceUtil;
import com.engine.core.impl.Service; import com.engine.core.impl.Service;
import com.engine.organization.common.BaseQueryParam; import com.engine.organization.entity.comp.param.CompSearchParam;
import com.engine.organization.service.CompService; import com.engine.organization.service.CompService;
import com.engine.organization.service.impl.CompServiceImpl; import com.engine.organization.service.impl.CompServiceImpl;
import weaver.hrm.User; import weaver.hrm.User;
@ -26,7 +26,7 @@ public class CompWrapper extends Service {
* @param params * @param params
* @return * @return
*/ */
public Map<String, Object> listPage(BaseQueryParam params) { public Map<String, Object> listPage(CompSearchParam params) {
return getCompService(user).listPage(params); return getCompService(user).listPage(params);
} }
} }

Loading…
Cancel
Save