Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
J
jyzb_platformV2
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Members
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
赵剑炜
jyzb_platformV2
Commits
af5594e9
Commit
af5594e9
authored
Aug 25, 2023
by
李小惠
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
1
parent
ce2cec73
隐藏空白字符变更
内嵌
并排
正在显示
14 个修改的文件
包含
174 行增加
和
39 行删除
+174
-39
EquipmentSizeDto.java
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/dto/EquipmentSizeDto.java
+18
-3
OrgDto.java
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/dto/OrgDto.java
+1
-0
QueryOrgReq.java
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/query/QueryOrgReq.java
+1
-0
UpdateOrgReq.java
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/req/UpdateOrgReq.java
+1
-1
EquipmentSizeController.java
jyzb-biz/src/main/java/com/junmp/jyzb/controller/EquipmentSizeController.java
+7
-0
InventoryController.java
jyzb-biz/src/main/java/com/junmp/jyzb/controller/InventoryController.java
+3
-3
EquipmentSizeMapper.java
jyzb-biz/src/main/java/com/junmp/jyzb/mapper/EquipmentSizeMapper.java
+22
-0
EquipmentSizeService.java
jyzb-biz/src/main/java/com/junmp/jyzb/service/EquipmentSizeService.java
+2
-0
PubOrgService.java
jyzb-biz/src/main/java/com/junmp/jyzb/service/PubOrgService.java
+0
-2
EquipmentSizeServiceImpl.java
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/EquipmentSizeServiceImpl.java
+15
-0
InventoryServiceImpl.java
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/InventoryServiceImpl.java
+36
-6
PubOrgServiceImpl.java
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/PubOrgServiceImpl.java
+13
-2
EquipmentSizeMapper.xml
jyzb-biz/src/main/resources/mapper/EquipmentSizeMapper.xml
+50
-16
pom.xml
pom.xml
+5
-6
没有找到文件。
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/dto/EquipmentSizeDto.java
View file @
af5594e9
...
...
@@ -35,10 +35,25 @@ public class EquipmentSizeDto {
private
String
name
;
/**
*
创建时间
*
装备名称
*/
private
Date
createTime
;
private
String
eqName
;
/**
* 类别1名称
*/
private
String
type1Name
;
/**
* 类别2名称
*/
private
String
type2name
;
/**
* 类别3名称
*/
private
String
type3Name
;
/**
* 类别汇总名称
*/
private
String
combinedTypes
;
/**
* 更新时间
*/
...
...
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/dto/OrgDto.java
View file @
af5594e9
...
...
@@ -12,5 +12,6 @@ public class OrgDto {
private
String
areaName
;
private
String
levelFlag
;
private
String
dName
;
private
Boolean
isLeaf
;
}
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/query/QueryOrgReq.java
View file @
af5594e9
...
...
@@ -12,6 +12,7 @@ public class QueryOrgReq {
private
String
parentId
;
private
Integer
isDepartment
;
private
Integer
level
;
private
Integer
delFlag
;
}
jyzb-api/src/main/java/com/junmp/jyzb/api/bean/req/UpdateOrgReq.java
View file @
af5594e9
...
...
@@ -14,7 +14,7 @@ public class UpdateOrgReq {
* 状态
*/
@NotNull
(
message
=
"状态不能为空"
,
groups
=
{
ValidationApi
.
updateStatus
.
class
})
private
Integer
status
Flag
;
private
Integer
del
Flag
;
/**
* 组织机构列表
*/
...
...
jyzb-biz/src/main/java/com/junmp/jyzb/controller/EquipmentSizeController.java
View file @
af5594e9
package
com
.
junmp
.
jyzb
.
controller
;
import
cn.hutool.db.Page
;
import
com.junmp.jyzb.api.bean.dto.EquipmentSizeDto
;
import
com.junmp.jyzb.api.bean.query.QueryEquipmentSizeReq
;
import
com.junmp.jyzb.api.bean.req.UpdateEquipmentSizeReq
;
...
...
@@ -7,6 +8,7 @@ import com.junmp.jyzb.entity.EquipmentSize;
import
com.junmp.jyzb.service.EquipmentSizeService
;
import
com.junmp.v2.common.bean.request.ValidationApi
;
import
com.junmp.v2.common.bean.response.ApiRes
;
import
com.junmp.v2.db.api.page.PageResult
;
import
io.swagger.annotations.Api
;
import
io.swagger.annotations.ApiOperation
;
import
lombok.extern.slf4j.Slf4j
;
...
...
@@ -53,6 +55,11 @@ public class EquipmentSizeController {
public
ApiRes
<
List
<
EquipmentSizeDto
>>
getAllSize
(
@RequestBody
QueryEquipmentSizeReq
req
){
return
ApiRes
.
success
(
equipmentSizeService
.
getAllSize
(
req
));
}
@PostMapping
(
"/GetSizePage"
)
@ApiOperation
(
"分页查询号型信息"
)
public
ApiRes
<
PageResult
<
EquipmentSizeDto
>>
getSizePage
(
@RequestBody
QueryEquipmentSizeReq
req
){
return
ApiRes
.
success
(
equipmentSizeService
.
getSizePages
(
req
));
}
@PostMapping
(
"/UpdateSize"
)
@ApiOperation
(
"修改号型信息"
)
...
...
jyzb-biz/src/main/java/com/junmp/jyzb/controller/InventoryController.java
View file @
af5594e9
...
...
@@ -71,15 +71,15 @@ public class InventoryController {
return
ApiRes
.
success
(
inventoryService
.
UpdateCabinetInsNum
(
req
));
}
//根据Epc获取装备
简要
信息
//根据Epc获取装备信息
@PostMapping
(
"/GetInvInfoByEpc"
)
@ApiOperation
(
"根据EPC列表获取装备信息
(简要)
"
)
@ApiOperation
(
"根据EPC列表获取装备信息"
)
public
ApiRes
<
List
<
InventoryDto
>>
GetInvInfoByEpc
(
@RequestBody
InventoryReq
req
){
return
ApiRes
.
success
(
inventoryService
.
GetInvInfoByEpc
(
req
));
}
//根据组织机构id/单警柜id/仓库id查询出库存的汇总信息
√
//根据组织机构id/单警柜id/仓库id查询出库存的汇总信息
(page)
@PostMapping
(
"/GetEquipmentInfo"
)
@ApiOperation
(
"根据条件查询库存汇总信息"
)
public
ApiRes
<
PageResult
<
InventorySummary
>>
getEquipmentInfo
(
@RequestBody
InventorySumReq
req
)
{
...
...
jyzb-biz/src/main/java/com/junmp/jyzb/mapper/EquipmentSizeMapper.java
View file @
af5594e9
package
com
.
junmp
.
jyzb
.
mapper
;
import
com.baomidou.mybatisplus.core.mapper.BaseMapper
;
import
com.baomidou.mybatisplus.extension.plugins.pagination.Page
;
import
com.junmp.jyzb.api.bean.dto.EquipmentSizeDto
;
import
com.junmp.jyzb.api.bean.query.QueryEquipmentSizeReq
;
import
com.junmp.jyzb.entity.Cabinet
;
import
com.junmp.jyzb.entity.EquipmentSize
;
import
org.apache.ibatis.annotations.Mapper
;
import
org.apache.ibatis.annotations.Param
;
import
java.util.List
;
import
java.util.Map
;
...
...
@@ -10,4 +15,20 @@ import java.util.Map;
@Mapper
public
interface
EquipmentSizeMapper
extends
BaseMapper
<
EquipmentSize
>
{
/**
* 获取分页的信息
*/
public
List
<
EquipmentSizeDto
>
getSizePage
(
@Param
(
"req"
)
QueryEquipmentSizeReq
req
,
@Param
(
"page"
)
Page
<
EquipmentSizeDto
>
page
);
/**
* 获取分页的信息
*/
public
Integer
getSizeCount
(
@Param
(
"name"
)
String
name
,
@Param
(
"typeId"
)
String
typeId
);
}
\ No newline at end of file
jyzb-biz/src/main/java/com/junmp/jyzb/service/EquipmentSizeService.java
View file @
af5594e9
...
...
@@ -6,6 +6,7 @@ import com.junmp.jyzb.api.bean.query.QueryEquipmentSizeReq;
import
com.junmp.jyzb.api.bean.req.UpdateEquipmentSizeReq
;
import
com.junmp.jyzb.entity.EquipmentSize
;
import
com.junmp.jyzb.utils.ResponseResult
;
import
com.junmp.v2.db.api.page.PageResult
;
import
java.util.List
;
...
...
@@ -21,4 +22,5 @@ public interface EquipmentSizeService extends IService<EquipmentSize> {
Boolean
changeSizeState
(
UpdateEquipmentSizeReq
req
);
List
<
EquipmentSizeDto
>
getAllSize
(
QueryEquipmentSizeReq
req
);
PageResult
<
EquipmentSizeDto
>
getSizePages
(
QueryEquipmentSizeReq
req
);
}
jyzb-biz/src/main/java/com/junmp/jyzb/service/PubOrgService.java
View file @
af5594e9
...
...
@@ -27,6 +27,4 @@ public interface PubOrgService extends IService<PubOrg> {
//根据组织机构id查询出组织机构是否存在
PubOrg
PubOrgExist
(
Long
id
);
}
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/EquipmentSizeServiceImpl.java
View file @
af5594e9
...
...
@@ -2,6 +2,7 @@ package com.junmp.jyzb.service.impl;
import
cn.hutool.core.util.ObjectUtil
;
import
com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper
;
import
com.baomidou.mybatisplus.extension.plugins.pagination.Page
;
import
com.baomidou.mybatisplus.extension.service.impl.ServiceImpl
;
import
com.junmp.jyzb.api.bean.dto.EquipmentSizeDto
;
import
com.junmp.jyzb.api.bean.dto.EquipmentTypeDto
;
...
...
@@ -9,6 +10,7 @@ import com.junmp.jyzb.api.bean.query.QueryEquipmentSizeReq;
import
com.junmp.jyzb.api.bean.req.UpdateEquipmentSizeReq
;
import
com.junmp.jyzb.api.exception.enums.ProductExceptionEnum
;
import
com.junmp.jyzb.entity.EquipmentSize
;
import
com.junmp.jyzb.entity.ProductSku
;
import
com.junmp.jyzb.mapper.EquipmentTypeMapper
;
import
com.junmp.jyzb.service.EquipmentSizeService
;
import
com.junmp.jyzb.utils.DateTimeUtil
;
...
...
@@ -17,6 +19,9 @@ import com.junmp.jyzb.utils.ResponseResult;
import
com.junmp.jyzb.utils.ReturnMsg
;
import
com.junmp.v2.common.exception.base.ServiceException
;
import
com.junmp.v2.common.util.BeanPlusUtil
;
import
com.junmp.v2.db.api.factory.PageFactory
;
import
com.junmp.v2.db.api.factory.PageResultFactory
;
import
com.junmp.v2.db.api.page.PageResult
;
import
org.springframework.stereotype.Service
;
import
javax.annotation.Resource
;
import
com.junmp.jyzb.mapper.EquipmentSizeMapper
;
...
...
@@ -83,6 +88,16 @@ public class EquipmentSizeServiceImpl extends ServiceImpl<EquipmentSizeMapper, E
}
return
dtoList
;
}
@Override
public
PageResult
<
EquipmentSizeDto
>
getSizePages
(
QueryEquipmentSizeReq
req
)
{
Page
<
EquipmentSizeDto
>
page
=
PageFactory
.
getDefaultPage
(
req
.
getPageNo
(),
req
.
getPageSize
());
List
<
EquipmentSizeDto
>
voList
=
equipmentSizeMapper
.
getSizePage
(
req
,
page
);
page
.
setRecords
(
voList
);
return
PageResultFactory
.
createPageResult
(
page
);
}
private
EquipmentSize
querySize
(
UpdateEquipmentSizeReq
req
)
{
EquipmentSize
app
=
this
.
getById
(
req
.
getId
());
...
...
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/InventoryServiceImpl.java
View file @
af5594e9
...
...
@@ -213,8 +213,18 @@ public class InventoryServiceImpl extends ServiceImpl<InventoryMapper, Inventory
}
else
{
throw
new
ServiceException
(
CabinetExceptionEnum
.
PARAMETER_ERROR
);
}
long
pageSize
=
20L
;
long
pageNo
=
1L
;
long
pageSize
;
long
pageNo
;
if
(
ObjectUtil
.
isNull
(
req
.
getPageNo
())){
pageNo
=
1L
;
}
else
{
pageNo
=
req
.
getPageNo
();
}
if
(
ObjectUtil
.
isNull
(
req
.
getPageSize
())){
pageSize
=
20L
;
}
else
{
pageSize
=
req
.
getPageSize
();
}
Page
<
InventoryDto
>
page
=
new
Page
<>(
pageNo
,
pageSize
);
IPage
<
InventoryDto
>
pages
=
inventoryMapper
.
EqsByTypePage
(
page
,
req
.
getQueryType
(),
req
.
getOrgId
(),
req
.
getWarehouseId
(),
req
.
getCabinetId
());
page
.
setRecords
(
pages
.
getRecords
());
...
...
@@ -266,8 +276,18 @@ public class InventoryServiceImpl extends ServiceImpl<InventoryMapper, Inventory
//判断货架是否存在
Shelf
shelf
=
shelfService
.
ShelfExist
(
req
.
getShelfId
());
warehouseService
.
WarehoustExist
(
shelf
.
getWarehouseId
());
long
pageSize
=
20L
;
long
pageNo
=
1L
;
long
pageSize
;
long
pageNo
;
if
(
ObjectUtil
.
isNull
(
req
.
getPageNo
())){
pageNo
=
1L
;
}
else
{
pageNo
=
req
.
getPageNo
();
}
if
(
ObjectUtil
.
isNull
(
req
.
getPageSize
())){
pageSize
=
20L
;
}
else
{
pageSize
=
req
.
getPageSize
();
}
Page
<
InventorySummary
>
page
=
new
Page
<>(
pageNo
,
pageSize
);
IPage
<
InventorySummary
>
pages
=
inventoryMapper
.
ShelfInventoryPage
(
page
,
req
.
getShelfId
());
pages
.
setRecords
(
pages
.
getRecords
());
...
...
@@ -319,8 +339,18 @@ public class InventoryServiceImpl extends ServiceImpl<InventoryMapper, Inventory
//判断区域是否存在
WarehouseArea
warehouseArea
=
warehouseAreaService
.
WarehouseAreaExist
(
req
.
getId
());
warehouseService
.
WarehoustExist
(
warehouseArea
.
getWarehouseId
());
long
pageSize
=
20L
;
long
pageNo
=
1L
;
long
pageSize
;
long
pageNo
;
if
(
ObjectUtil
.
isNull
(
req
.
getPageNo
())){
pageNo
=
1L
;
}
else
{
pageNo
=
req
.
getPageNo
();
}
if
(
ObjectUtil
.
isNull
(
req
.
getPageSize
())){
pageSize
=
20L
;
}
else
{
pageSize
=
req
.
getPageSize
();
}
Page
<
InventorySummary
>
page
=
new
Page
<>(
pageNo
,
pageSize
);
IPage
<
InventorySummary
>
pages
=
inventoryMapper
.
AreaInventoryPage
(
page
,
req
.
getId
());
page
.
setRecords
(
pages
.
getRecords
());
...
...
jyzb-biz/src/main/java/com/junmp/jyzb/service/impl/PubOrgServiceImpl.java
View file @
af5594e9
...
...
@@ -234,7 +234,7 @@ public class PubOrgServiceImpl extends ServiceImpl<PubOrgMapper, PubOrg> implem
List
<
PubOrg
>
st
=
list
(
wp
);
st
.
forEach
(
p
->
{
p
.
set
StatusFlag
(
req
.
getStatus
Flag
());
p
.
set
DelFlag
(
req
.
getDel
Flag
());
});
return
this
.
updateBatchById
(
st
);
...
...
@@ -329,12 +329,22 @@ public class PubOrgServiceImpl extends ServiceImpl<PubOrgMapper, PubOrg> implem
list
.
forEach
(
p
->{
OrgDto
org
=
new
OrgDto
();
BeanPlusUtil
.
copyProperties
(
p
,
org
);
// 判断是否有子节点
boolean
hasChildren
=
hasChildren
(
req
.
getDelFlag
(),
p
.
getOrgId
());
org
.
setIsLeaf
(!
hasChildren
);
orgs
.
add
(
org
);
});
return
orgs
;
}
// 判断是否有子节点的方法
private
boolean
hasChildren
(
Integer
Del
,
Long
parentId
)
{
LambdaQueryWrapper
<
PubOrg
>
wrapper
=
new
LambdaQueryWrapper
<>();
wrapper
.
eq
(
PubOrg:
:
getOrgParentId
,
parentId
);
wrapper
.
eq
(
ObjectUtil
.
isNotNull
(
Del
),
PubOrg:
:
getDelFlag
,
Del
);
Long
count
=
this
.
count
(
wrapper
);
return
count
>
0
;
}
public
List
<
OrgDto
>
getOrgList
(
QueryOrgReq
req
)
{
LambdaQueryWrapper
<
PubOrg
>
wp
=
this
.
createWrapper
(
req
);
List
<
PubOrg
>
list
=
this
.
list
(
wp
);
...
...
@@ -356,6 +366,7 @@ public class PubOrgServiceImpl extends ServiceImpl<PubOrgMapper, PubOrg> implem
wrapper
.
eq
(
ObjectUtil
.
isNotEmpty
(
req
.
getIsDepartment
()),
PubOrg:
:
getIsDepartment
,
req
.
getIsDepartment
());
//根据业务编码查询
wrapper
.
eq
(
ObjectUtil
.
isNotEmpty
(
req
.
getLevel
()),
PubOrg:
:
getLevelFlag
,
req
.
getLevel
());
wrapper
.
eq
(
ObjectUtil
.
isNotEmpty
(
req
.
getDelFlag
()),
PubOrg:
:
getDelFlag
,
req
.
getDelFlag
());
wrapper
.
eq
(
ObjectUtil
.
isNotEmpty
(
req
.
getParentId
()),
PubOrg:
:
getOrgParentId
,
req
.
getParentId
()
);
wrapper
.
eq
(
ObjectUtil
.
isNotEmpty
(
req
.
getOrgCode
()),
PubOrg:
:
getOrgCode
,
req
.
getOrgCode
());
...
...
jyzb-biz/src/main/resources/mapper/EquipmentSizeMapper.xml
View file @
af5594e9
<?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=
"com.junmp.jyzb.mapper.EquipmentSizeMapper"
>
<resultMap
id=
"BaseResultMap"
type=
"com.junmp.jyzb.entity.EquipmentSize"
>
<!--@mbg.generated-->
<!--@Table base_equipment_size-->
<id
column=
"id"
jdbcType=
"VARCHAR"
property=
"id"
/>
<result
column=
"type_id"
jdbcType=
"VARCHAR"
property=
"typeId"
/>
<result
column=
"code"
jdbcType=
"INTEGER"
property=
"code"
/>
<result
column=
"name"
jdbcType=
"VARCHAR"
property=
"name"
/>
<result
column=
"create_time"
jdbcType=
"TIMESTAMP"
property=
"createTime"
/>
<result
column=
"update_time"
jdbcType=
"TIMESTAMP"
property=
"updateTime"
/>
<result
column=
"note"
jdbcType=
"VARCHAR"
property=
"note"
/>
<result
column=
"epc_type"
jdbcType=
"INTEGER"
property=
"epcType"
/>
</resultMap>
<sql
id=
"Base_Column_List"
>
<!--@mbg.generated-->
id, type_id, detail_id, code, `name`, create_time, update_time, note, epc_type
</sql>
<select
id=
"getSizePage"
resultType=
"com.junmp.jyzb.api.bean.dto.EquipmentSizeDto"
>
SELECT
t1.id,
t1.state,
t2.name AS eqName,
t1.name AS name,
t1.type_id as typeId,
t1.price,
t1.code AS code,
t3.name AS type3Name,
t4.name AS type2name,
t5.name AS type1Name,
CONCAT_WS(' / ', t5.name, t4.name, t3.name) AS combinedTypes
FROM
`base_equipment_size` t1
LEFT JOIN `base_equipment_type` t2 ON t1.type_id = t2.id
LEFT JOIN `base_equipment_type` t3 ON t2.parent_id = t3.id
LEFT JOIN `base_equipment_type` t4 ON t3.parent_id = t4.id
LEFT JOIN `base_equipment_type` t5 ON t4.parent_id = t5.id
LEFT JOIN `base_equipment_type` t6 ON t5.parent_id = t6.id
WHERE 1 = 1
<if
test=
"null != req"
>
<if
test=
"null != req.name"
>
AND t1.name LIKE CONCAT('%', #{req.name}, '%')
</if>
<if
test=
"null != req.typeId and '' != req.typeId"
>
AND t1.type_id= #{req.typeId}
</if>
</if>
</select>
<select
id=
"getSizeCount"
resultType=
"int"
>
SELECT
COUNT(*)
FROM
`base_equipment_size` t1
LEFT JOIN `base_equipment_type` t2 ON t1.type_id = t2.id
LEFT JOIN `base_equipment_type` t3 ON t2.parent_id = t3.id
LEFT JOIN `base_equipment_type` t4 ON t3.parent_id = t4.id
LEFT JOIN `base_equipment_type` t5 ON t4.parent_id = t5.id
LEFT JOIN `base_equipment_type` t6 ON t5.parent_id = t6.id
<if
test=
"name != null and name != ''"
>
AND t1.name LIKE CONCAT('%', #{name}, '%')
</if>
<if
test=
"typeId != null and typeId != ''"
>
AND t1.type_id= #{typeId}
</if>
</select>
</mapper>
\ No newline at end of file
pom.xml
View file @
af5594e9
...
...
@@ -50,7 +50,6 @@
<project.reporting.outputEncoding>
UTF-8
</project.reporting.outputEncoding>
<spring-boot-maven-plugin.version>
2.5.0
</spring-boot-maven-plugin.version>
<java.version>
1.8
</java.version>
<mysql-connector-java.version>
8.0.21
</mysql-connector-java.version>
<mybatis-plus-boot-starter>
3.5.1
</mybatis-plus-boot-starter>
<junmp.v2.version>
1.0.0
</junmp.v2.version>
<spring.ds.version>
3.5.1
</spring.ds.version>
...
...
@@ -259,11 +258,11 @@
</dependency>
<!-- bcrypt依赖 -->
<dependency
>
<groupId>
org.springframework.security
</groupId
>
<artifactId>
spring-security-web
</artifactId
>
<version>
5.0.5.RELEASE
</version
>
</dependency
>
<!-- <dependency>--
>
<!-- <groupId>org.springframework.security</groupId>--
>
<!-- <artifactId>spring-security-web</artifactId>--
>
<!-- <version>5.0.5.RELEASE</version>--
>
<!-- </dependency>--
>
<!--导入导出依赖-->
<dependency>
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论