订单详情页优化

This commit is contained in:
Vinjor 2024-11-19 15:11:08 +08:00
parent 9f9320f7a0
commit 0adeb3b6c6
9 changed files with 138 additions and 19 deletions

View File

@ -39,6 +39,6 @@ public class TicketsAPI {
@Operation(summary = "维修工单表 查看一个工单的详细信息") @Operation(summary = "维修工单表 查看一个工单的详细信息")
@TenantIgnore @TenantIgnore
public CommonResult<?> getTicketsById(@RequestParam(value = "id") String id){ public CommonResult<?> getTicketsById(@RequestParam(value = "id") String id){
return success(dlRepairTicketsService.getTicketsById(id)); return success(dlRepairTicketsService.getTicketsById(id,null));
} }
} }

View File

@ -74,13 +74,14 @@ public class DlRepairTicketsController {
* 获得一个工单的详细信息 * 获得一个工单的详细信息
* *
* @param id 工单ID * @param id 工单ID
* @param ifApp 是否是APP发起的查询
* @author 小李 * @author 小李
* @date 16:05 2024/9/21 * @date 16:05 2024/9/21
**/ **/
@GetMapping("/get") @GetMapping("/get")
@Operation(summary = "查看一个工单的详细信息") @Operation(summary = "查看一个工单的详细信息")
public CommonResult<?> getTicketsById(@RequestParam("id") String id) { public CommonResult<?> getTicketsById(@RequestParam("id") String id,@RequestParam("ifApp")Boolean ifApp) {
return success(dlRepairTicketsService.getTicketsById(id)); return success(dlRepairTicketsService.getTicketsById(id,ifApp));
} }
/** /**

View File

@ -1,6 +1,7 @@
package cn.iocoder.yudao.module.tickets.mapper; package cn.iocoder.yudao.module.tickets.mapper;
import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem; import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem;
import cn.iocoder.yudao.module.tickets.vo.DlRepairTitemReqVO;
import cn.iocoder.yudao.module.tickets.vo.DlRepairTitemRespVO; import cn.iocoder.yudao.module.tickets.vo.DlRepairTitemRespVO;
import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.metadata.IPage;
@ -42,6 +43,15 @@ public interface DlRepairTitemMapper extends BaseMapper<DlRepairTitem> {
* @return java.util.List<cn.iocoder.yudao.module.tickets.vo.DlRepairTitemRespVO> * @return java.util.List<cn.iocoder.yudao.module.tickets.vo.DlRepairTitemRespVO>
**/ **/
List<DlRepairTitemRespVO> selectProjList(@Param("ticketId")String ticketId,@Param("isOpen")String isOpen); List<DlRepairTitemRespVO> selectProjList(@Param("ticketId")String ticketId,@Param("isOpen")String isOpen);
/**
* 根据工单ID查询所有配件明细--带着分组名称和ID
* @author vinjor-M
* @date 10:44 2024/11/19
* @param ticketId 工单ID
* @return java.util.List<cn.iocoder.yudao.module.tickets.vo.DlRepairTitemReqVO>
**/
List<DlRepairTitemReqVO> selectByTicketId(@Param("ticketId")String ticketId);
} }

View File

@ -42,10 +42,11 @@ public interface DlRepairTicketsService extends IService<DlRepairTickets> {
* 获得一个工单的详细信息 * 获得一个工单的详细信息
* *
* @param id 工单ID * @param id 工单ID
* @param ifApp 是否是APP发起的查询
* @author 小李 * @author 小李
* @date 16:05 2024/9/21 * @date 16:05 2024/9/21
**/ **/
DlRepairTicketsRespVO getTicketsById(String id); DlRepairTicketsRespVO getTicketsById(String id,Boolean ifApp);
/** /**
* 维修工单表 作废 * 维修工单表 作废

View File

@ -52,6 +52,7 @@ import cn.iocoder.yudao.module.tickets.entity.DlRepairTitem;
import cn.iocoder.yudao.module.tickets.entity.DlTicketWares; import cn.iocoder.yudao.module.tickets.entity.DlTicketWares;
import cn.iocoder.yudao.module.tickets.entity.DlTwItem; import cn.iocoder.yudao.module.tickets.entity.DlTwItem;
import cn.iocoder.yudao.module.tickets.mapper.DlRepairTicketsMapper; import cn.iocoder.yudao.module.tickets.mapper.DlRepairTicketsMapper;
import cn.iocoder.yudao.module.tickets.mapper.DlRepairTitemMapper;
import cn.iocoder.yudao.module.tickets.service.DlRepairTicketsService; import cn.iocoder.yudao.module.tickets.service.DlRepairTicketsService;
import cn.iocoder.yudao.module.tickets.service.DlRepairTitemService; import cn.iocoder.yudao.module.tickets.service.DlRepairTitemService;
import cn.iocoder.yudao.module.tickets.service.DlTicketWaresService; import cn.iocoder.yudao.module.tickets.service.DlTicketWaresService;
@ -105,6 +106,8 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
@Resource @Resource
private DlRepairTitemService titemService; private DlRepairTitemService titemService;
@Resource @Resource
private DlRepairTitemMapper repairTitemMapper;
@Resource
private DlRepairTicketsMapper repairTicketsMapper; private DlRepairTicketsMapper repairTicketsMapper;
@Resource @Resource
@ -339,11 +342,12 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
* 获得一个工单的详细信息 * 获得一个工单的详细信息
* *
* @param id 工单ID * @param id 工单ID
* @param ifApp 是否是APP发起的查询
* @author 小李 * @author 小李
* @date 16:05 2024/9/21 * @date 16:05 2024/9/21
**/ **/
@Override @Override
public DlRepairTicketsRespVO getTicketsById(String id) { public DlRepairTicketsRespVO getTicketsById(String id,Boolean ifApp) {
// 查工单主表 // 查工单主表
DlRepairTickets dlRepairTickets = baseMapper.selectById(id); DlRepairTickets dlRepairTickets = baseMapper.selectById(id);
DlRepairTicketsRespVO result = BeanUtil.toBean(dlRepairTickets, DlRepairTicketsRespVO.class); DlRepairTicketsRespVO result = BeanUtil.toBean(dlRepairTickets, DlRepairTicketsRespVO.class);
@ -370,21 +374,59 @@ public class DlRepairTicketsServiceImpl extends ServiceImpl<DlRepairTicketsMappe
} }
result.setProjects(projects); result.setProjects(projects);
// 取配件 if(ifApp){
List<DlRepairTitemReqVO> wares = items.stream().filter(item -> item.getItemType().equals("02")).collect(Collectors.toList()); //app的逻辑
if (CollectionUtil.isNotEmpty(wares)) { List<AppWaresGroupVO> waresGroupList = new ArrayList<>();
// 单位字典 //查这个工单的配件
List<DictDataRespDTO> recordTypeList = dictDataApi.getDictDataList(DICT_REPAIR_UNIT); List<DlRepairTitemReqVO> waresList = repairTitemMapper.selectByTicketId(id);
Map<String, String> unitMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue, DictDataRespDTO::getLabel)); if (CollectionUtil.isNotEmpty(waresList)) {
//先过滤出itenTypeId为null或空或者itemTypeName为null或空的为单独一个组
Set<String> ids = wares.stream().map(DlRepairTitemReqVO::getPartId).collect(Collectors.toSet()); List<DlRepairTitemReqVO> nullList = waresList.stream().filter(item->StringUtils.isEmpty(item.getItemTypeId()) || StringUtils.isEmpty(item.getItemTypeName())).collect(Collectors.toList());
List<RepairWares> repairWares = waresService.listByIds(ids); if (CollectionUtil.isNotEmpty(nullList)) {
items.forEach(item -> { AppWaresGroupVO waresGroupVO = new AppWaresGroupVO();
repairWares.stream().filter(i -> i.getId().equals(item.getPartId())).findFirst().ifPresent(item::setWare); waresGroupVO.setWares(nullList);
item.setItemUnit(unitMap.get(item.getItemUnit())); waresGroupVO.setGroupName("未知分组");
}); waresGroupVO.setNums(nullList.size());
waresGroupVO.setTotalAmount(nullList.stream().peek(item->{
if(null==item.getItemMoney()){
item.setItemMoney(new BigDecimal(0));
}
}).map(DlRepairTitem::getItemMoney).reduce(BigDecimal.ZERO,BigDecimal::add));
waresGroupList.add(waresGroupVO);
}
//过滤出有分类的进行分组
Map<String,List<DlRepairTitemReqVO>> groupListMap = waresList.stream().filter(item->StringUtils.isNotEmpty(item.getItemTypeId()) && StringUtils.isNotEmpty(item.getItemTypeName())).collect(Collectors.groupingBy(DlRepairTitem::getItemTypeId));
for (String key:groupListMap.keySet()){
AppWaresGroupVO waresGroupVO = new AppWaresGroupVO();
waresGroupVO.setWares(groupListMap.get(key));
waresGroupVO.setGroupName(groupListMap.get(key).get(0).getItemTypeName());
waresGroupVO.setGroupId(key);
waresGroupVO.setNums(groupListMap.get(key).size());
waresGroupVO.setTotalAmount(groupListMap.get(key).stream().peek(item->{
if(null==item.getItemMoney()){
item.setItemMoney(new BigDecimal(0));
}
}).map(DlRepairTitem::getItemMoney).reduce(BigDecimal.ZERO,BigDecimal::add));
waresGroupList.add(waresGroupVO);
}
}
result.setWaresGroupList(waresGroupList);
}else{
// 取配件----原有逻辑-电脑端
List<DlRepairTitemReqVO> wares = items.stream().filter(item -> item.getItemType().equals("02")).collect(Collectors.toList());
if (CollectionUtil.isNotEmpty(wares)) {
// 单位字典
List<DictDataRespDTO> recordTypeList = dictDataApi.getDictDataList(DICT_REPAIR_UNIT);
Map<String, String> unitMap = recordTypeList.stream().collect(Collectors.toMap(DictDataRespDTO::getValue, DictDataRespDTO::getLabel));
Set<String> ids = wares.stream().map(DlRepairTitemReqVO::getPartId).collect(Collectors.toSet());
List<RepairWares> repairWares = waresService.listByIds(ids);
items.forEach(item -> {
repairWares.stream().filter(i -> i.getId().equals(item.getPartId())).findFirst().ifPresent(item::setWare);
item.setUnitText(unitMap.get(item.getItemUnit()));
});
}
result.setWares(wares);
} }
result.setWares(wares);
// 取附加 // 取附加
List<DlRepairTitemReqVO> others = items.stream().filter(item -> item.getItemType().equals("03")).collect(Collectors.toList()); List<DlRepairTitemReqVO> others = items.stream().filter(item -> item.getItemType().equals("03")).collect(Collectors.toList());
if (CollectionUtil.isNotEmpty(others)) { if (CollectionUtil.isNotEmpty(others)) {

View File

@ -0,0 +1,25 @@
package cn.iocoder.yudao.module.tickets.vo;
import lombok.Data;
import java.math.BigDecimal;
import java.util.List;
/**
* app使用的配件明细按分类分组后的
* @author vinjor-M
* @date 10:10 2024/11/19
**/
@Data
public class AppWaresGroupVO {
/** 分组ID分类ID */
private String groupId;
/** 分组名称(分类名称) */
private String groupName;
/** 数量 */
private Integer nums;
/** 总价 */
private BigDecimal totalAmount;
/** 配件明细 */
private List<DlRepairTitemReqVO> wares;
}

View File

@ -63,4 +63,6 @@ public class DlRepairTicketsRespVO extends DlRepairTickets {
/** 维修班组长是否可以重新派工--当前施工人是自己或者本班组内的人员 */ /** 维修班组长是否可以重新派工--当前施工人是自己或者本班组内的人员 */
private Boolean canOperate; private Boolean canOperate;
/** app分组回显专用--配件明细 */
List<AppWaresGroupVO> waresGroupList;
} }

View File

@ -23,4 +23,9 @@ public class DlRepairTitemReqVO extends DlRepairTitem {
// 附加详情 // 附加详情
private DlRepairOther other; private DlRepairOther other;
/** 配件分类名称 */
private String itemTypeName;
/** 配件单位名称 */
private String unitText;
} }

View File

@ -109,4 +109,37 @@
drt.update_time, drt.update_time,
drri.create_time drri.create_time
</select> </select>
<select id="selectByTicketId" resultType="cn.iocoder.yudao.module.tickets.vo.DlRepairTitemReqVO">
SELECT
drt.id,
drt.ticket_id,
drt.item_name ,
drt.item_count ,
drt.item_unit ,
drt.item_price ,
drt.item_discount ,
drt.item_money ,
drt.item_type ,
drt.part_id ,
drt.item_status ,
drt.remark ,
drt.tenant_id ,
drt.deleted ,
drt.creator ,
drt.create_time ,
drt.updater ,
drt.update_time,
drw.type AS item_type_id,
dbt.`name` AS item_type_name,
sdd.label AS unit_text
FROM
dl_repair_titem drt
LEFT JOIN dl_repair_wares drw ON drt.part_id = drw.id
LEFT JOIN dl_base_type dbt ON drw.type = dbt.id
LEFT JOIN system_dict_data sdd ON drw.unit = sdd.value AND sdd.dict_type='repair_unit'
WHERE drt.ticket_id = #{ticketId}
AND drt.item_type = '02'
AND drt.deleted = '0'
ORDER BY drw.type,drt.create_time
</select>
</mapper> </mapper>