分包商
This commit is contained in:
@ -1,13 +1,17 @@
|
|||||||
package com.ruoyi.web.controller.bgt;
|
package com.ruoyi.web.controller.bgt;
|
||||||
|
|
||||||
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
import com.ruoyi.bgt.domain.dto.BgtLeaveUpdateDTO;
|
import com.ruoyi.bgt.domain.dto.BgtLeaveUpdateDTO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtLeaveDetailVO;
|
||||||
import com.ruoyi.common.annotation.Log;
|
import com.ruoyi.common.annotation.Log;
|
||||||
import com.ruoyi.common.annotation.RepeatSubmit;
|
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||||
import com.ruoyi.common.core.controller.BaseController;
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
import com.ruoyi.common.core.domain.AjaxResult;
|
import com.ruoyi.common.core.domain.AjaxResult;
|
||||||
import com.ruoyi.common.enums.BusinessType;
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
import com.ruoyi.wgz.domain.WgzLeave;
|
import com.ruoyi.wgz.domain.WgzLeave;
|
||||||
|
import com.ruoyi.wgz.domain.WgzUser;
|
||||||
import com.ruoyi.wgz.service.IWgzLeaveService;
|
import com.ruoyi.wgz.service.IWgzLeaveService;
|
||||||
|
import com.ruoyi.wgz.service.IWgzUserService;
|
||||||
import io.swagger.annotations.Api;
|
import io.swagger.annotations.Api;
|
||||||
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiOperation;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
@ -30,15 +34,20 @@ import javax.validation.constraints.NotNull;
|
|||||||
public class AppBgtLeaveController extends BaseController {
|
public class AppBgtLeaveController extends BaseController {
|
||||||
|
|
||||||
private final IWgzLeaveService iWgzLeaveService;
|
private final IWgzLeaveService iWgzLeaveService;
|
||||||
|
private final IWgzUserService wgzUserService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取请假详细信息
|
* 获取请假详细信息
|
||||||
*/
|
*/
|
||||||
@ApiOperation("获取请假详细信息")
|
@ApiOperation("获取请假详细信息")
|
||||||
@GetMapping("/{id}")
|
@GetMapping("/{id}")
|
||||||
public AjaxResult<WgzLeave> getInfo(@NotNull(message = "主键不能为空")
|
public AjaxResult<BgtLeaveDetailVO> getInfo(@NotNull(message = "主键不能为空")
|
||||||
@PathVariable("id") Long id) {
|
@PathVariable("id") Long id) {
|
||||||
return AjaxResult.success(iWgzLeaveService.queryById(id));
|
WgzLeave wgzLeave = iWgzLeaveService.queryById(id);
|
||||||
|
WgzUser byUserId = wgzUserService.findByUserId(wgzLeave.getUserId());
|
||||||
|
BgtLeaveDetailVO bgtLeaveDetailVO = BeanUtil.copyProperties(wgzLeave, BgtLeaveDetailVO.class);
|
||||||
|
bgtLeaveDetailVO.setAvatarName(byUserId.getAvatarName());
|
||||||
|
return AjaxResult.success(bgtLeaveDetailVO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiOperation("请假审核")
|
@ApiOperation("请假审核")
|
||||||
|
@ -0,0 +1,72 @@
|
|||||||
|
package com.ruoyi.web.controller.fbs;
|
||||||
|
|
||||||
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
|
import com.ruoyi.common.core.domain.AjaxResult;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.fbs.domain.FbsMessage;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageDetailDTO;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageMyListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageCountVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageDetailVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageVO;
|
||||||
|
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息Controller
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
@Api(value = "App分包商消息控制器", tags = {"App分包商"})
|
||||||
|
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/app/fbs/message")
|
||||||
|
public class AppFbsMessageController extends BaseController {
|
||||||
|
|
||||||
|
private final IFbsMessageService iFbsMessageService;
|
||||||
|
|
||||||
|
@ApiOperation("分包商未读消息统计")
|
||||||
|
@GetMapping("/countUnread")
|
||||||
|
public AjaxResult<FbsMessageCountVO> count() {
|
||||||
|
return AjaxResult.success(iFbsMessageService.countUnread());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("分包商消息列表")
|
||||||
|
@GetMapping("/myList")
|
||||||
|
public TableDataInfo<FbsMessageVO> myList(FbsMessageMyListDTO dto) {
|
||||||
|
return iFbsMessageService.queryMyPageList(dto);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("分包商消息详情列表")
|
||||||
|
@GetMapping("/detailList")
|
||||||
|
public TableDataInfo<FbsMessageDetailVO> otherList(FbsMessageDetailDTO dto) {
|
||||||
|
return iFbsMessageService.queryDetailPageList(dto);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("分包商消息已读")
|
||||||
|
@PutMapping("/read/{id}")
|
||||||
|
public AjaxResult<Boolean> read(@PathVariable(value = "id") Long id) {
|
||||||
|
FbsMessage fbsMessage = new FbsMessage();
|
||||||
|
fbsMessage.setId(id);
|
||||||
|
fbsMessage.setReadStatus("1");
|
||||||
|
return AjaxResult.success(iFbsMessageService.updateById(fbsMessage));
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiOperation("分包商消息已操作")
|
||||||
|
@PutMapping("/operation/{id}")
|
||||||
|
public AjaxResult<Boolean> operation(@PathVariable(value = "id") Long id) {
|
||||||
|
FbsMessage fbsMessage = new FbsMessage();
|
||||||
|
fbsMessage.setId(id);
|
||||||
|
fbsMessage.setIsOperation("2");
|
||||||
|
return AjaxResult.success(iFbsMessageService.updateById(fbsMessage));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,5 +1,10 @@
|
|||||||
package com.ruoyi.web.controller.fbs;
|
package com.ruoyi.web.controller.fbs;
|
||||||
|
|
||||||
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import com.ruoyi.bgt.domain.BgtWageApplication;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtWageApplicationDetailVO;
|
||||||
|
import com.ruoyi.bgt.domain.vo.BgtWageApplicationVO;
|
||||||
|
import com.ruoyi.bgt.service.IBgtWageApplicationService;
|
||||||
import com.ruoyi.common.annotation.Log;
|
import com.ruoyi.common.annotation.Log;
|
||||||
import com.ruoyi.common.annotation.RepeatSubmit;
|
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||||
import com.ruoyi.common.core.controller.BaseController;
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
@ -8,7 +13,10 @@ import com.ruoyi.common.core.page.TableDataInfo;
|
|||||||
import com.ruoyi.common.enums.BusinessType;
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
import com.ruoyi.fbs.domain.FbsWageApplication;
|
import com.ruoyi.fbs.domain.FbsWageApplication;
|
||||||
import com.ruoyi.fbs.domain.dto.FbsWageApplicationListDTO;
|
import com.ruoyi.fbs.domain.dto.FbsWageApplicationListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsWageAuditDTO;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsWageAuditListDTO;
|
||||||
import com.ruoyi.fbs.service.IFbsWageApplicationService;
|
import com.ruoyi.fbs.service.IFbsWageApplicationService;
|
||||||
|
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||||
import io.swagger.annotations.Api;
|
import io.swagger.annotations.Api;
|
||||||
import io.swagger.annotations.ApiOperation;
|
import io.swagger.annotations.ApiOperation;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.RequiredArgsConstructor;
|
||||||
@ -24,13 +32,15 @@ import javax.validation.constraints.NotNull;
|
|||||||
* @author ruoyi
|
* @author ruoyi
|
||||||
* @date 2025-03-26
|
* @date 2025-03-26
|
||||||
*/
|
*/
|
||||||
@Api(value = "APP分包商工资申请控制器", tags = {"APP分包商"})
|
@Api(value = "App分包商工资申请控制器", tags = {"App分包商"})
|
||||||
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||||
@RestController
|
@RestController
|
||||||
@RequestMapping("/app/fbs/application")
|
@RequestMapping("/app/fbs/application")
|
||||||
public class AppFbsWageApplicationController extends BaseController {
|
public class AppFbsWageApplicationController extends BaseController {
|
||||||
|
|
||||||
private final IFbsWageApplicationService iFbsWageApplicationService;
|
private final IFbsWageApplicationService iFbsWageApplicationService;
|
||||||
|
private final IBgtWageApplicationService iBgtWageApplicationService;
|
||||||
|
private final IZbfProjectService iZbfProjectService;
|
||||||
|
|
||||||
@ApiOperation("分包商查询自己的工资申请列表")
|
@ApiOperation("分包商查询自己的工资申请列表")
|
||||||
@GetMapping("/list")
|
@GetMapping("/list")
|
||||||
@ -50,8 +60,35 @@ public class AppFbsWageApplicationController extends BaseController {
|
|||||||
@RepeatSubmit
|
@RepeatSubmit
|
||||||
@PostMapping()
|
@PostMapping()
|
||||||
public AjaxResult<Boolean> add(@Validated @RequestBody FbsWageApplication bo) {
|
public AjaxResult<Boolean> add(@Validated @RequestBody FbsWageApplication bo) {
|
||||||
//todo: 插入审核人的名字
|
// ZbfProject byId = iZbfProjectService.getById(bo.getProjectId());
|
||||||
|
//
|
||||||
|
// bo.setReviewerName(byId.getUnitName())
|
||||||
return AjaxResult.success(iFbsWageApplicationService.insert(bo));
|
return AjaxResult.success(iFbsWageApplicationService.insert(bo));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ApiOperation("分包商查询审核工资申请列表")
|
||||||
|
@GetMapping("/audit/list")
|
||||||
|
public TableDataInfo<BgtWageApplicationVO> auditList(@Validated FbsWageAuditListDTO dto) {
|
||||||
|
return iBgtWageApplicationService.fbsAuditPageList(dto);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiOperation("分包商查询审核工资申请详细信息")
|
||||||
|
@GetMapping("/audit/{id}")
|
||||||
|
public AjaxResult<BgtWageApplicationDetailVO> getAuditInfo(@NotNull(message = "主键不能为空")
|
||||||
|
@PathVariable("id") Long id) {
|
||||||
|
return AjaxResult.success(iBgtWageApplicationService.appQueryById(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
@ApiOperation("分包商审核包工头工资申请")
|
||||||
|
@Log(title = "分包商审核包工头工资申请", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PutMapping("/audit")
|
||||||
|
public AjaxResult<Boolean> audit(@Validated @RequestBody FbsWageAuditDTO dto) {
|
||||||
|
BgtWageApplication bo = iBgtWageApplicationService.getById(dto.getId());
|
||||||
|
BeanUtil.copyProperties(dto, bo);
|
||||||
|
return AjaxResult.success(iBgtWageApplicationService.update(bo));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,108 @@
|
|||||||
|
package com.ruoyi.web.controller.fbs;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import com.ruoyi.fbs.domain.FbsMessage;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import javax.validation.constraints.*;
|
||||||
|
import org.springframework.security.access.prepost.PreAuthorize;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.web.bind.annotation.*;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||||
|
import com.ruoyi.common.annotation.Log;
|
||||||
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
|
import com.ruoyi.common.core.domain.AjaxResult;
|
||||||
|
import com.ruoyi.common.enums.BusinessType;
|
||||||
|
import com.ruoyi.fbs.bo.FbsMessageQueryBo;
|
||||||
|
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||||
|
import com.ruoyi.common.utils.poi.ExcelUtil;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息Controller
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
@Api(value = "消息控制器", tags = {"消息管理"})
|
||||||
|
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/fbs/message")
|
||||||
|
public class FbsMessageController extends BaseController {
|
||||||
|
|
||||||
|
private final IFbsMessageService iFbsMessageService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询消息列表
|
||||||
|
*/
|
||||||
|
@ApiOperation("查询消息列表")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:list')")
|
||||||
|
@GetMapping("/list")
|
||||||
|
public TableDataInfo<FbsMessage> list(@Validated FbsMessageQueryBo bo) {
|
||||||
|
return iFbsMessageService.queryPageList(bo);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导出消息列表
|
||||||
|
*/
|
||||||
|
@ApiOperation("导出消息列表")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:export')")
|
||||||
|
@Log(title = "消息", businessType = BusinessType.EXPORT)
|
||||||
|
@GetMapping("/export")
|
||||||
|
public AjaxResult<FbsMessage> export(@Validated FbsMessageQueryBo bo) {
|
||||||
|
List<FbsMessage> list = iFbsMessageService.queryList(bo);
|
||||||
|
ExcelUtil<FbsMessage> util = new ExcelUtil<FbsMessage>(FbsMessage.class);
|
||||||
|
return util.exportExcel(list, "消息");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取消息详细信息
|
||||||
|
*/
|
||||||
|
@ApiOperation("获取消息详细信息")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:query')")
|
||||||
|
@GetMapping("/{id}")
|
||||||
|
public AjaxResult<FbsMessage> getInfo(@NotNull(message = "主键不能为空")
|
||||||
|
@PathVariable("id") Long id) {
|
||||||
|
return AjaxResult.success(iFbsMessageService.queryById(id));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 新增消息
|
||||||
|
*/
|
||||||
|
@ApiOperation("新增消息")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:add')")
|
||||||
|
@Log(title = "消息", businessType = BusinessType.INSERT)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PostMapping()
|
||||||
|
public AjaxResult<Void> add(@Validated @RequestBody FbsMessage bo) {
|
||||||
|
return toAjax(iFbsMessageService.insert(bo) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 修改消息
|
||||||
|
*/
|
||||||
|
@ApiOperation("修改消息")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:edit')")
|
||||||
|
@Log(title = "消息", businessType = BusinessType.UPDATE)
|
||||||
|
@RepeatSubmit
|
||||||
|
@PutMapping()
|
||||||
|
public AjaxResult<Void> edit(@Validated @RequestBody FbsMessage bo) {
|
||||||
|
return toAjax(iFbsMessageService.update(bo) ? 1 : 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除消息
|
||||||
|
*/
|
||||||
|
@ApiOperation("删除消息")
|
||||||
|
@PreAuthorize("@ss.hasPermi('fbs:message:remove')")
|
||||||
|
@Log(title = "消息" , businessType = BusinessType.DELETE)
|
||||||
|
@DeleteMapping("/{ids}")
|
||||||
|
public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||||
|
@PathVariable Long[] ids) {
|
||||||
|
return toAjax(iFbsMessageService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,37 @@
|
|||||||
|
package com.ruoyi.web.controller.fbs;
|
||||||
|
|
||||||
|
import com.ruoyi.common.core.controller.BaseController;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsProjectSectionListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO;
|
||||||
|
import com.ruoyi.zbf.service.IZbfProjectSectionService;
|
||||||
|
import io.swagger.annotations.Api;
|
||||||
|
import io.swagger.annotations.ApiOperation;
|
||||||
|
import lombok.RequiredArgsConstructor;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.validation.annotation.Validated;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 总包方项目标段Controller
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-17
|
||||||
|
*/
|
||||||
|
@Api(value = "App分包商项目标段控制器", tags = {"App分包商"})
|
||||||
|
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||||
|
@RestController
|
||||||
|
@RequestMapping("/app/fbs/section")
|
||||||
|
public class FbsProjectSectionController extends BaseController {
|
||||||
|
|
||||||
|
private final IZbfProjectSectionService iZbfProjectSectionService;
|
||||||
|
|
||||||
|
@ApiOperation("分包商查询自己的项目分包列表")
|
||||||
|
@GetMapping("/fbsSubList")
|
||||||
|
public TableDataInfo<FbsProjectSectionListVO> fbsSubList(@Validated FbsProjectSectionListDTO dto) {
|
||||||
|
return iZbfProjectSectionService.fbsSubList(dto);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -7,9 +7,9 @@ package com.ruoyi.common.enums;
|
|||||||
*/
|
*/
|
||||||
public enum BgtMessageType
|
public enum BgtMessageType
|
||||||
{
|
{
|
||||||
TASK("1", "包工头同意"),
|
TASK("1", "任务/报名"),
|
||||||
SETTLEMENT("2", "包工头拒绝"),
|
SETTLEMENT("2", "结算"),
|
||||||
OTHER("3", "务工者同意"),
|
OTHER("3", "其他"),
|
||||||
;
|
;
|
||||||
|
|
||||||
private final String code;
|
private final String code;
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
package com.ruoyi.bgt.domain;
|
package com.ruoyi.bgt.domain;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
|
||||||
import com.ruoyi.common.annotation.Excel;
|
import com.ruoyi.common.annotation.Excel;
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
@ -32,7 +29,7 @@ public class BgtWageApplication implements Serializable {
|
|||||||
|
|
||||||
/** 主键ID */
|
/** 主键ID */
|
||||||
@ApiModelProperty("主键ID")
|
@ApiModelProperty("主键ID")
|
||||||
@TableId(value = "id")
|
@TableId(value = "id", type = IdType.AUTO)
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
/** 项目ID */
|
/** 项目ID */
|
||||||
@ -85,7 +82,7 @@ public class BgtWageApplication implements Serializable {
|
|||||||
private String cardNo;
|
private String cardNo;
|
||||||
|
|
||||||
@ApiModelProperty("申请时间")
|
@ApiModelProperty("申请时间")
|
||||||
private String applyTime;
|
private LocalDateTime applyTime;
|
||||||
|
|
||||||
/** 申请金额 */
|
/** 申请金额 */
|
||||||
@Excel(name = "申请金额")
|
@Excel(name = "申请金额")
|
||||||
@ -117,6 +114,9 @@ public class BgtWageApplication implements Serializable {
|
|||||||
@ApiModelProperty("审核人Id")
|
@ApiModelProperty("审核人Id")
|
||||||
private Long reviewerId;
|
private Long reviewerId;
|
||||||
|
|
||||||
|
@ApiModelProperty("审核人名字")
|
||||||
|
private String reviewerName;
|
||||||
|
|
||||||
/** 删除标志(0代表存在 2代表删除) */
|
/** 删除标志(0代表存在 2代表删除) */
|
||||||
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
|
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
|
||||||
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||||
|
@ -0,0 +1,108 @@
|
|||||||
|
package com.ruoyi.bgt.domain.vo;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.LocalTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 请假对象 wgz_leave
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-19
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@ApiModel("请假视图对象")
|
||||||
|
public class BgtLeaveDetailVO {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/** 主键自增ID */
|
||||||
|
@ApiModelProperty("主键自增ID")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("项目ID")
|
||||||
|
private Long recruitId;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("招工申请主键自增id")
|
||||||
|
private Long applyKey;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("请假人")
|
||||||
|
private Long userId;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("招工主题")
|
||||||
|
private String subject;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("请假类型(字典)")
|
||||||
|
private String leaveType;
|
||||||
|
|
||||||
|
@ApiModelProperty("开始时间")
|
||||||
|
private LocalDateTime startTime;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("结束时间")
|
||||||
|
private LocalDateTime endTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("请假事由")
|
||||||
|
private String reason;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("审核人ID")
|
||||||
|
private Long auditorUserId;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("审核状态(0待审核 1审核中 2已同意 3已拒绝 4=已取消)")
|
||||||
|
private String auditorType;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("审核意见")
|
||||||
|
private String auditorOpinion;
|
||||||
|
|
||||||
|
@ApiModelProperty("同意|拒绝时间")
|
||||||
|
private LocalDateTime auditorTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("上班时间")
|
||||||
|
private LocalTime workingTime;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("下班时间")
|
||||||
|
private LocalTime closingTime;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("取消请假")
|
||||||
|
private LocalDateTime cancelLeave;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||||
|
private String delFlag;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("创建者")
|
||||||
|
private String createBy;
|
||||||
|
|
||||||
|
@ApiModelProperty("创建时间")
|
||||||
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("更新者")
|
||||||
|
private String updateBy;
|
||||||
|
|
||||||
|
|
||||||
|
@ApiModelProperty("更新时间")
|
||||||
|
private LocalDateTime updateTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("备注")
|
||||||
|
private String remark;
|
||||||
|
|
||||||
|
@ApiModelProperty("头像地址")
|
||||||
|
private String avatarName;
|
||||||
|
|
||||||
|
}
|
@ -45,8 +45,8 @@ public class BgtWageApplicationDetailVO {
|
|||||||
private String username;
|
private String username;
|
||||||
|
|
||||||
@ApiModelProperty("申请时间")
|
@ApiModelProperty("申请时间")
|
||||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm")
|
||||||
private LocalDateTime createTime;
|
private LocalDateTime applyTime;
|
||||||
|
|
||||||
@ApiModelProperty("联系电话")
|
@ApiModelProperty("联系电话")
|
||||||
private String phone;
|
private String phone;
|
||||||
|
@ -36,8 +36,8 @@ public class BgtWageApplicationVO {
|
|||||||
private BigDecimal applicantAmount;
|
private BigDecimal applicantAmount;
|
||||||
|
|
||||||
@ApiModelProperty("申请时间")
|
@ApiModelProperty("申请时间")
|
||||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm")
|
||||||
private LocalDateTime createTime;
|
private LocalDateTime applyTime;
|
||||||
|
|
||||||
@ApiModelProperty("任务名")
|
@ApiModelProperty("任务名")
|
||||||
private String taskName;
|
private String taskName;
|
||||||
|
@ -7,6 +7,7 @@ import com.ruoyi.bgt.domain.vo.BgtWageApplicationListVO;
|
|||||||
import com.ruoyi.bgt.domain.vo.BgtWageApplicationVO;
|
import com.ruoyi.bgt.domain.vo.BgtWageApplicationVO;
|
||||||
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||||
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsWageAuditListDTO;
|
||||||
import org.apache.ibatis.annotations.CacheNamespace;
|
import org.apache.ibatis.annotations.CacheNamespace;
|
||||||
import org.apache.ibatis.annotations.Param;
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
@ -25,4 +26,9 @@ public interface BgtWageApplicationMapper extends BaseMapperPlus<BgtWageApplicat
|
|||||||
Page<BgtWageApplicationVO> appQueryPageList(@Param("page") Page<BgtWageApplicationQueryDTO> page, @Param("dto") BgtWageApplicationQueryDTO dto);
|
Page<BgtWageApplicationVO> appQueryPageList(@Param("page") Page<BgtWageApplicationQueryDTO> page, @Param("dto") BgtWageApplicationQueryDTO dto);
|
||||||
|
|
||||||
List<BgtWageApplicationListVO> appQueryList(@Param("dto") BgtWageApplicationQueryDTO dto);
|
List<BgtWageApplicationListVO> appQueryList(@Param("dto") BgtWageApplicationQueryDTO dto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分包商查询包工头的工资申请
|
||||||
|
*/
|
||||||
|
Page<BgtWageApplicationVO> fbsAuditPageList(@Param("page") Page<FbsWageAuditListDTO> page, @Param("dto") FbsWageAuditListDTO dto);
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@ import com.ruoyi.bgt.domain.vo.BgtWageApplicationListVO;
|
|||||||
import com.ruoyi.bgt.domain.vo.BgtWageApplicationVO;
|
import com.ruoyi.bgt.domain.vo.BgtWageApplicationVO;
|
||||||
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsWageAuditListDTO;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -71,4 +72,11 @@ public interface IBgtWageApplicationService extends IServicePlus<BgtWageApplicat
|
|||||||
* 查询不分页列表
|
* 查询不分页列表
|
||||||
*/
|
*/
|
||||||
List<BgtWageApplicationListVO> appQueryList(BgtWageApplicationQueryDTO dto);
|
List<BgtWageApplicationListVO> appQueryList(BgtWageApplicationQueryDTO dto);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分包商查询审核列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<BgtWageApplicationVO> fbsAuditPageList(FbsWageAuditListDTO dto);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,9 @@ import com.ruoyi.bgt.service.IBgtWageApplicationService;
|
|||||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
import com.ruoyi.common.utils.PageUtils;
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
|
import com.ruoyi.common.utils.SecurityUtils;
|
||||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsWageAuditListDTO;
|
||||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
@ -151,4 +153,14 @@ public class BgtWageApplicationServiceImpl extends ServicePlusImpl<BgtWageApplic
|
|||||||
public List<BgtWageApplicationListVO> appQueryList(BgtWageApplicationQueryDTO dto) {
|
public List<BgtWageApplicationListVO> appQueryList(BgtWageApplicationQueryDTO dto) {
|
||||||
return baseMapper.appQueryList(dto);
|
return baseMapper.appQueryList(dto);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<BgtWageApplicationVO> fbsAuditPageList(FbsWageAuditListDTO dto) {
|
||||||
|
Page<FbsWageAuditListDTO> queryDTOPage = new Page<>();
|
||||||
|
queryDTOPage.setCurrent(dto.getPageNum());
|
||||||
|
queryDTOPage.setSize(dto.getPageSize());
|
||||||
|
dto.setReviewerId(SecurityUtils.getAppUserId());
|
||||||
|
Page<BgtWageApplicationVO> queryVOPage = baseMapper.fbsAuditPageList(queryDTOPage, dto);
|
||||||
|
return PageUtils.buildDataInfo(queryVOPage);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,140 @@
|
|||||||
|
package com.ruoyi.common.constants;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class FbsMessageConstant {
|
||||||
|
// 公共常量
|
||||||
|
|
||||||
|
public static final String FBS_LARGE_TASK = "1"; //大类型-任务
|
||||||
|
public static final String FBS_LARGE_SETTLEMENT = "2"; //大类型-结算
|
||||||
|
public static final String FBS_LARGE_OTHER = "3"; //大类型-其它
|
||||||
|
|
||||||
|
public static final String FBS_SMALL_SIGN_UP = "1"; //小类型-包工头报名
|
||||||
|
public static final String FBS_SMALL_PAY = "2"; //小类型-付款
|
||||||
|
public static final String FBS_SMALL_LEAVE = "3"; //小类型-进度
|
||||||
|
|
||||||
|
public static final List<String> AUDIT_TYPE = Arrays.asList("2", "3");
|
||||||
|
/**
|
||||||
|
* ============================================分包商->包工头 模板==================================================
|
||||||
|
* ============================================分包商->包工头 模板==================================================
|
||||||
|
* ============================================分包商->包工头 模板==================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
//任务审批
|
||||||
|
public static final String FBS_SIGN_UP_APPLY_HEADLINE = "您申请的【%s】任务,已得到回复!";
|
||||||
|
public static final String FBS_SIGN_UP_APPLY_SUBHEADING = "您申请的【%s】任务,审核人【%s】已%s!";
|
||||||
|
//工资审批
|
||||||
|
public static final String FBS_PAY_APPLY_HEADLINE = "您【%s】任务工资申请已审批!";
|
||||||
|
public static final String FBS_PAY_APPLY_SUBHEADING = "您申请的【%s】任务工资,审核人【%s】已%s!";
|
||||||
|
//进度审批
|
||||||
|
public static final String FBS_PROGRESS_HEADLINE = "您【%s】任务的上传进度已审批!";
|
||||||
|
public static final String FBS_PROGRESS_SUBHEADING = "您【%s】任务的上传进度,审核人【%s】已%s!";
|
||||||
|
|
||||||
|
|
||||||
|
//分包商->包工头 消息类型
|
||||||
|
public static final String FBS_TYPE_SIGN_UP = "1"; //包工头报名
|
||||||
|
public static final String FBS_TYPE_PAY = "2"; //付款
|
||||||
|
public static final String FBS_TYPE_PROGRESS = "3"; //进度
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ============================================系统->分包商 模板==================================================
|
||||||
|
* ============================================系统->分包商 模板==================================================
|
||||||
|
* ============================================系统->分包商 模板==================================================
|
||||||
|
*/
|
||||||
|
//承接任务
|
||||||
|
public static final String FBS_SUB_APPLY_HEADLINE = "您已成功申请【%s】项目【%s】分包";
|
||||||
|
public static final String FBS_SUB_APPLY_SUBHEADING = "您已成功申请到【%s】项目【%s】分包,请耐心等待回复!";
|
||||||
|
//取消承接任务
|
||||||
|
public static final String FBS_TASK_APPLY_CANCEL_HEADLINE = "您已成功取消【%s】项目【%s】分包申请!";
|
||||||
|
public static final String FBS_TASK_APPLY_CANCEL_SUBHEADING = "您已成功取消【%s】项目【%s】分包申请";
|
||||||
|
//工资结算
|
||||||
|
public static final String FBS_SETTLEMENT_APPLY_HEADLINE = "您正在申请【%s】项目【%s】分包,总共【%s】元的工资结算操作!";
|
||||||
|
public static final String FBS_SETTLEMENT_APPLY_SUBHEADING = "您已成功发起金额为【%s】元的工资结算操作,请耐心等待回复!";
|
||||||
|
|
||||||
|
|
||||||
|
//系统->包工头 消息类型
|
||||||
|
public static final String FBS_TYPE_TASK = "4"; //任务报名
|
||||||
|
public static final String FBS_TYPE_TASK_CANCEL = "5"; //任务取消
|
||||||
|
public static final String FBS_TYPE_SETTLEMENT = "6"; //结算
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ============================================分包商->总包方 模板==================================================
|
||||||
|
* ============================================分包商->总包方 模板==================================================
|
||||||
|
* ============================================分包商->总包方 模板==================================================
|
||||||
|
*/
|
||||||
|
//承接任务
|
||||||
|
public static final String FBS_TO_ZBF_APPLY_SUB_HEADLINE = "分包商【%s】正在向你申请承接【%s】项目【%s】分包!";
|
||||||
|
public static final String FBS_TO_ZBF_APPLY_SUB_SUBHEADING = "分包商【%s】正在向你申请承接【%s】项目【%s】分包,您可点击查看更多信息!";
|
||||||
|
//工资结算
|
||||||
|
public static final String FBS_TO_ZBF_SETTLEMENT_APPLY_HEADLINE = "分包商【%s】正在向你发起工资结算!";
|
||||||
|
public static final String FBS_TO_ZBF_SETTLEMENT_APPLY_SUBHEADING = "分包商【%s】向你发起金额为【%s】元的工资结算操作!";
|
||||||
|
|
||||||
|
//分包商->总包方 消息类型
|
||||||
|
public static final String FBS_TYPE_SUB_TO_ZBF = "7"; //任务
|
||||||
|
public static final String FBS_TYPE_SETTLEMEN_TO_FBGT = "8"; //结算
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ============================================调用方法==================================================
|
||||||
|
* ============================================调用方法==================================================
|
||||||
|
* ============================================调用方法==================================================
|
||||||
|
*/
|
||||||
|
//主副标志
|
||||||
|
public static final String HEADLINE = "headline"; //主标题
|
||||||
|
public static final String SUBHEADING = "subheading"; //副标题
|
||||||
|
|
||||||
|
//包工头消息返回
|
||||||
|
public static Map<String, String> bgtMessage(Map<String, String> mp, String type, Boolean isPass) {
|
||||||
|
Map<String, String> map = new HashMap<>();
|
||||||
|
String pass = isPass ? "通过" : "拒绝";
|
||||||
|
String projectName = mp.get("projectName");
|
||||||
|
String subName = mp.get("subName");
|
||||||
|
String auditor = mp.get("auditor");
|
||||||
|
String amount = mp.get("amount");
|
||||||
|
switch (type) {
|
||||||
|
case "1":
|
||||||
|
map.put(HEADLINE, String.format(FBS_SIGN_UP_APPLY_HEADLINE, projectName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_SIGN_UP_APPLY_SUBHEADING, projectName, auditor, pass));
|
||||||
|
break;
|
||||||
|
case "2":
|
||||||
|
map.put(HEADLINE, String.format(FBS_PAY_APPLY_HEADLINE, projectName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_PAY_APPLY_SUBHEADING, projectName, auditor, pass));
|
||||||
|
break;
|
||||||
|
case "3":
|
||||||
|
map.put(HEADLINE, String.format(FBS_PROGRESS_HEADLINE, projectName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_PROGRESS_SUBHEADING, projectName, auditor, pass));
|
||||||
|
break;
|
||||||
|
case "4":
|
||||||
|
map.put(HEADLINE, String.format(FBS_SUB_APPLY_HEADLINE, projectName,subName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_SUB_APPLY_SUBHEADING, projectName,subName));
|
||||||
|
break;
|
||||||
|
case "5":
|
||||||
|
map.put(HEADLINE, String.format(FBS_TASK_APPLY_CANCEL_HEADLINE, projectName,subName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_TASK_APPLY_CANCEL_SUBHEADING, projectName,subName));
|
||||||
|
break;
|
||||||
|
case "6":
|
||||||
|
map.put(HEADLINE, String.format(FBS_SETTLEMENT_APPLY_HEADLINE, projectName,subName,amount));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_SETTLEMENT_APPLY_SUBHEADING, amount));
|
||||||
|
break;
|
||||||
|
case "7":
|
||||||
|
map.put(HEADLINE, String.format(FBS_TO_ZBF_APPLY_SUB_HEADLINE, auditor, projectName,subName));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_TO_ZBF_APPLY_SUB_SUBHEADING, auditor, projectName,subName));
|
||||||
|
break;
|
||||||
|
case "8":
|
||||||
|
map.put(HEADLINE, String.format(FBS_TO_ZBF_SETTLEMENT_APPLY_HEADLINE, auditor));
|
||||||
|
map.put(SUBHEADING, String.format(FBS_TO_ZBF_SETTLEMENT_APPLY_SUBHEADING, auditor,amount));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,79 @@
|
|||||||
|
package com.ruoyi.fbs.bo;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import com.ruoyi.common.core.domain.BaseEntity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息分页查询对象 fbs_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
@ApiModel("消息分页查询对象")
|
||||||
|
public class FbsMessageQueryBo extends BaseEntity {
|
||||||
|
|
||||||
|
/** 分页大小 */
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
/** 排序列 */
|
||||||
|
@ApiModelProperty("排序列")
|
||||||
|
private String orderByColumn;
|
||||||
|
/** 排序的方向desc或者asc */
|
||||||
|
@ApiModelProperty(value = "排序的方向", example = "asc,desc")
|
||||||
|
private String isAsc;
|
||||||
|
|
||||||
|
|
||||||
|
/** 发送类型(0系统 1务工者 2包工头 3分包商 4总包方) */
|
||||||
|
@ApiModelProperty("发送类型(0系统 1务工者 2包工头 3分包商 4总包方)")
|
||||||
|
private String senderType;
|
||||||
|
/** 发送人 */
|
||||||
|
@ApiModelProperty("发送人")
|
||||||
|
private Long senderId;
|
||||||
|
/** 接收类型(1务工者 2包工头 3分包商 4总包方) */
|
||||||
|
@ApiModelProperty("接收类型(1务工者 2包工头 3分包商 4总包方)")
|
||||||
|
private String recipientType;
|
||||||
|
/** 接收人 */
|
||||||
|
@ApiModelProperty("接收人")
|
||||||
|
private Long recipientId;
|
||||||
|
/** 标题 */
|
||||||
|
@ApiModelProperty("标题")
|
||||||
|
private String headline;
|
||||||
|
/** 副标题 */
|
||||||
|
@ApiModelProperty("副标题")
|
||||||
|
private String subheading;
|
||||||
|
/** 表ID */
|
||||||
|
@ApiModelProperty("表ID")
|
||||||
|
private Long tableId;
|
||||||
|
/** 表名 */
|
||||||
|
@ApiModelProperty("表名")
|
||||||
|
private String tableName;
|
||||||
|
/** 大类型(字典bgt_message_large_type) */
|
||||||
|
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||||
|
private String messageLargeType;
|
||||||
|
/** 小类型(字典bgt_message_small_type) */
|
||||||
|
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||||
|
private String messageSmallType;
|
||||||
|
/** 读状态(0未读 1已读) */
|
||||||
|
@ApiModelProperty("读状态(0未读 1已读)")
|
||||||
|
private String readStatus;
|
||||||
|
/** 是否需要操作(0不需要 1需要 2已操作) */
|
||||||
|
@ApiModelProperty("是否需要操作(0不需要 1需要 2已操作)")
|
||||||
|
private String isOperation;
|
||||||
|
|
||||||
|
}
|
133
ruoyi-system/src/main/java/com/ruoyi/fbs/domain/FbsMessage.java
Normal file
133
ruoyi-system/src/main/java/com/ruoyi/fbs/domain/FbsMessage.java
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
package com.ruoyi.fbs.domain;
|
||||||
|
|
||||||
|
import com.ruoyi.common.annotation.Excel;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 fbs_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@TableName("fbs_message")
|
||||||
|
@ApiModel("消息视图对象")
|
||||||
|
public class FbsMessage implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
/** 主键自增ID */
|
||||||
|
@ApiModelProperty("主键自增ID")
|
||||||
|
@TableId(value = "id")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
/** 发送类型(0系统 1务工者 2包工头 3分包商 4总包方) */
|
||||||
|
@Excel(name = "发送类型" , readConverterExp = "0=系统,1=务工者,2=包工头,3=分包商,4=总包方")
|
||||||
|
@ApiModelProperty("发送类型(0系统 1务工者 2包工头 3分包商 4总包方)")
|
||||||
|
private String senderType;
|
||||||
|
|
||||||
|
/** 发送人 */
|
||||||
|
@Excel(name = "发送人")
|
||||||
|
@ApiModelProperty("发送人")
|
||||||
|
private Long senderId;
|
||||||
|
|
||||||
|
/** 接收类型(1务工者 2包工头 3分包商 4总包方) */
|
||||||
|
@Excel(name = "接收类型" , readConverterExp = "1=务工者,2=包工头,3=分包商,4=总包方")
|
||||||
|
@ApiModelProperty("接收类型(1务工者 2包工头 3分包商 4总包方)")
|
||||||
|
private String recipientType;
|
||||||
|
|
||||||
|
/** 接收人 */
|
||||||
|
@Excel(name = "接收人")
|
||||||
|
@ApiModelProperty("接收人")
|
||||||
|
private Long recipientId;
|
||||||
|
|
||||||
|
/** 标题 */
|
||||||
|
@Excel(name = "标题")
|
||||||
|
@ApiModelProperty("标题")
|
||||||
|
private String headline;
|
||||||
|
|
||||||
|
/** 副标题 */
|
||||||
|
@Excel(name = "副标题")
|
||||||
|
@ApiModelProperty("副标题")
|
||||||
|
private String subheading;
|
||||||
|
|
||||||
|
/** 表ID */
|
||||||
|
@Excel(name = "表ID")
|
||||||
|
@ApiModelProperty("表ID")
|
||||||
|
private Long tableId;
|
||||||
|
|
||||||
|
/** 表名 */
|
||||||
|
@Excel(name = "表名")
|
||||||
|
@ApiModelProperty("表名")
|
||||||
|
private String tableName;
|
||||||
|
|
||||||
|
/** 大类型(字典bgt_message_large_type) */
|
||||||
|
@Excel(name = "大类型" , readConverterExp = "字=典bgt_message_large_type")
|
||||||
|
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||||
|
private String messageLargeType;
|
||||||
|
|
||||||
|
/** 小类型(字典bgt_message_small_type) */
|
||||||
|
@Excel(name = "小类型" , readConverterExp = "字=典bgt_message_small_type")
|
||||||
|
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||||
|
private String messageSmallType;
|
||||||
|
|
||||||
|
/** 读状态(0未读 1已读) */
|
||||||
|
@Excel(name = "读状态" , readConverterExp = "0=未读,1=已读")
|
||||||
|
@ApiModelProperty("读状态(0未读 1已读)")
|
||||||
|
private String readStatus;
|
||||||
|
|
||||||
|
/** 删除标志(0代表存在 2代表删除) */
|
||||||
|
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
|
||||||
|
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||||
|
private String delFlag;
|
||||||
|
|
||||||
|
/** 创建者 */
|
||||||
|
@Excel(name = "创建者")
|
||||||
|
@ApiModelProperty("创建者")
|
||||||
|
@TableField(fill = FieldFill.INSERT)
|
||||||
|
private String createBy;
|
||||||
|
|
||||||
|
/** 创建时间 */
|
||||||
|
@Excel(name = "创建时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||||
|
@ApiModelProperty("创建时间")
|
||||||
|
@TableField(fill = FieldFill.INSERT)
|
||||||
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
|
/** 更新者 */
|
||||||
|
@Excel(name = "更新者")
|
||||||
|
@ApiModelProperty("更新者")
|
||||||
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||||
|
private String updateBy;
|
||||||
|
|
||||||
|
/** 更新时间 */
|
||||||
|
@Excel(name = "更新时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||||
|
@ApiModelProperty("更新时间")
|
||||||
|
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||||
|
private LocalDateTime updateTime;
|
||||||
|
|
||||||
|
/** 备注 */
|
||||||
|
@Excel(name = "备注")
|
||||||
|
@ApiModelProperty("备注")
|
||||||
|
private String remark;
|
||||||
|
|
||||||
|
/** 是否需要操作(0不需要 1需要 2已操作) */
|
||||||
|
@Excel(name = "是否需要操作" , readConverterExp = "0=不需要,1=需要,2=已操作")
|
||||||
|
@ApiModelProperty("是否需要操作(0不需要 1需要 2已操作)")
|
||||||
|
private String isOperation;
|
||||||
|
|
||||||
|
}
|
@ -1,9 +1,7 @@
|
|||||||
package com.ruoyi.fbs.domain;
|
package com.ruoyi.fbs.domain;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
|
||||||
import com.ruoyi.common.annotation.Excel;
|
import com.ruoyi.common.annotation.Excel;
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
@ -32,7 +30,7 @@ public class FbsWageApplication implements Serializable {
|
|||||||
|
|
||||||
/** 主键ID */
|
/** 主键ID */
|
||||||
@ApiModelProperty("主键ID")
|
@ApiModelProperty("主键ID")
|
||||||
@TableId(value = "id")
|
@TableId(value = "id", type = IdType.AUTO)
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
/** 项目ID */
|
/** 项目ID */
|
||||||
@ -98,6 +96,7 @@ public class FbsWageApplication implements Serializable {
|
|||||||
/** 申请时间 */
|
/** 申请时间 */
|
||||||
@Excel(name = "申请时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
@Excel(name = "申请时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||||
@ApiModelProperty("申请时间")
|
@ApiModelProperty("申请时间")
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm")
|
||||||
private LocalDateTime applyTime;
|
private LocalDateTime applyTime;
|
||||||
|
|
||||||
/** 用工情况 */
|
/** 用工情况 */
|
||||||
|
@ -0,0 +1,46 @@
|
|||||||
|
package com.ruoyi.fbs.domain.dto;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
import org.springframework.format.annotation.DateTimeFormat;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 bgt_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-25
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("分包商消息详情查询对象")
|
||||||
|
public class FbsMessageDetailDTO {
|
||||||
|
|
||||||
|
/** 分页大小 */
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
|
||||||
|
@ApiModelProperty("日期")
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||||
|
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||||
|
private LocalDate date;
|
||||||
|
|
||||||
|
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||||
|
private String messageLargeType;
|
||||||
|
|
||||||
|
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||||
|
private String messageSmallType;
|
||||||
|
|
||||||
|
@ApiModelProperty("是否待处理")
|
||||||
|
private Boolean isHandle = false;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
package com.ruoyi.fbs.domain.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 bgt_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-25
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("消息列表查询对象")
|
||||||
|
public class FbsMessageMyListDTO {
|
||||||
|
|
||||||
|
/** 分页大小 */
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,23 @@
|
|||||||
|
package com.ruoyi.fbs.domain.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@ApiModel("分包商项目列表查询条件")
|
||||||
|
public class FbsProjectSectionListDTO {
|
||||||
|
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
|
||||||
|
@ApiModelProperty("项目Id")
|
||||||
|
private Long projectId;
|
||||||
|
|
||||||
|
@ApiModelProperty(value = "分包商Id",hidden = true)
|
||||||
|
private Long fbsUserId;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
package com.ruoyi.fbs.domain.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 包工头工资申请分页查询对象 bgt_wage_application
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-20
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@ApiModel("App包工头工资申请分页查询对象")
|
||||||
|
public class FbsWageAuditDTO {
|
||||||
|
|
||||||
|
@ApiModelProperty("主键ID")
|
||||||
|
@NotNull(message = "主键ID不能为空")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@ApiModelProperty("审核状态(1审核中 2已审核 3未通过)")
|
||||||
|
private String auditStatus;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,41 @@
|
|||||||
|
package com.ruoyi.fbs.domain.dto;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 包工头工资申请分页查询对象 bgt_wage_application
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-20
|
||||||
|
*/
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@ApiModel("App包工头工资申请分页查询对象")
|
||||||
|
public class FbsWageAuditListDTO {
|
||||||
|
|
||||||
|
/** 分页大小 */
|
||||||
|
@ApiModelProperty("分页大小")
|
||||||
|
private Integer pageSize;
|
||||||
|
/** 当前页数 */
|
||||||
|
@ApiModelProperty("当前页数")
|
||||||
|
private Integer pageNum;
|
||||||
|
|
||||||
|
@ApiModelProperty("任务ID")
|
||||||
|
private Long taskId;
|
||||||
|
|
||||||
|
@ApiModelProperty("任务名")
|
||||||
|
private String taskName;
|
||||||
|
/** 申请人ID */
|
||||||
|
@ApiModelProperty("审核人ID")
|
||||||
|
private Long reviewerId;
|
||||||
|
/** 审核状态(1审核中 2已审核 3未审核) */
|
||||||
|
// @ApiModelProperty("审核状态(1审核中 2已审核 3未通过)")
|
||||||
|
// private String auditStatus;
|
||||||
|
|
||||||
|
@ApiModelProperty("筛选(1申请中 2已结算)")
|
||||||
|
private Integer type;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,36 @@
|
|||||||
|
package com.ruoyi.fbs.domain.vo;
|
||||||
|
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 bgt_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-25
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("分包商未读消息统计视图对象")
|
||||||
|
public class FbsMessageCountVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
@ApiModelProperty("申请消息")
|
||||||
|
private Integer taskMessageCount;
|
||||||
|
|
||||||
|
@ApiModelProperty("结算消息")
|
||||||
|
private Integer settlementMessageCount;
|
||||||
|
|
||||||
|
@ApiModelProperty("其他消息")
|
||||||
|
private Integer otherMessageCount;
|
||||||
|
|
||||||
|
@ApiModelProperty("待处理消息")
|
||||||
|
private Integer handleMessageCount;
|
||||||
|
}
|
@ -0,0 +1,58 @@
|
|||||||
|
package com.ruoyi.fbs.domain.vo;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 bgt_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-25
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("分包商消息列表详情视图对象")
|
||||||
|
public class FbsMessageDetailVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
@ApiModelProperty("主键自增ID")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@ApiModelProperty("发送人")
|
||||||
|
@JsonFormat(shape = JsonFormat.Shape.STRING)
|
||||||
|
private Long senderId;
|
||||||
|
|
||||||
|
@ApiModelProperty("表ID")
|
||||||
|
private Long tableId;
|
||||||
|
|
||||||
|
@ApiModelProperty("标题")
|
||||||
|
private String headline;
|
||||||
|
|
||||||
|
@ApiModelProperty("副标题")
|
||||||
|
private String subheading;
|
||||||
|
|
||||||
|
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||||
|
private String messageLargeType;
|
||||||
|
|
||||||
|
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||||
|
private String messageSmallType;
|
||||||
|
|
||||||
|
@ApiModelProperty("读状态(0未读 1已读)")
|
||||||
|
private String readStatus;
|
||||||
|
|
||||||
|
@ApiModelProperty("创建时间")
|
||||||
|
@JsonFormat(pattern = "yyyy-MM-dd HH:mm")
|
||||||
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
|
@ApiModelProperty("是否需要操作(0不需要 1需要 2已操作)")
|
||||||
|
private String isOperation ;
|
||||||
|
}
|
@ -0,0 +1,55 @@
|
|||||||
|
package com.ruoyi.fbs.domain.vo;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||||
|
import io.swagger.annotations.ApiModel;
|
||||||
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.Accessors;
|
||||||
|
|
||||||
|
import java.io.Serializable;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息对象 bgt_message
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-02-25
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@NoArgsConstructor
|
||||||
|
@Accessors(chain = true)
|
||||||
|
@ApiModel("分包商消息列表视图对象")
|
||||||
|
public class FbsMessageVO implements Serializable {
|
||||||
|
|
||||||
|
private static final long serialVersionUID=1L;
|
||||||
|
|
||||||
|
@ApiModelProperty("主键自增ID")
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
@ApiModelProperty("表ID")
|
||||||
|
private Long tableId;
|
||||||
|
|
||||||
|
@ApiModelProperty("发送人")
|
||||||
|
@JsonFormat(shape = JsonFormat.Shape.STRING)
|
||||||
|
private Long senderId;
|
||||||
|
|
||||||
|
@ApiModelProperty("标题")
|
||||||
|
private String headline;
|
||||||
|
|
||||||
|
@ApiModelProperty("副标题")
|
||||||
|
private String subheading;
|
||||||
|
|
||||||
|
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||||
|
private String messageLargeType;
|
||||||
|
|
||||||
|
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||||
|
private String messageSmallType;
|
||||||
|
|
||||||
|
@ApiModelProperty("读状态(0未读 1已读)")
|
||||||
|
private String readStatus;
|
||||||
|
|
||||||
|
@ApiModelProperty("创建时间")
|
||||||
|
private LocalDateTime createTime;
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,18 @@
|
|||||||
|
package com.ruoyi.fbs.mapper;
|
||||||
|
|
||||||
|
import com.ruoyi.fbs.domain.FbsMessage;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||||
|
import org.apache.ibatis.annotations.CacheNamespace;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息Mapper接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
// 如使需切换数据源 请勿使用缓存 会造成数据不一致现象
|
||||||
|
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
||||||
|
public interface FbsMessageMapper extends BaseMapperPlus<FbsMessage> {
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,75 @@
|
|||||||
|
package com.ruoyi.fbs.service;
|
||||||
|
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.fbs.bo.FbsMessageQueryBo;
|
||||||
|
import com.ruoyi.fbs.domain.FbsMessage;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageDetailDTO;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageMyListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageCountVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageDetailVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageVO;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息Service接口
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
public interface IFbsMessageService extends IServicePlus<FbsMessage> {
|
||||||
|
/**
|
||||||
|
* 查询单个
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
FbsMessage queryById(Long id);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<FbsMessage> queryPageList(FbsMessageQueryBo bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询列表
|
||||||
|
*/
|
||||||
|
List<FbsMessage> queryList(FbsMessageQueryBo bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据新增业务对象插入消息
|
||||||
|
* @param bo 消息新增业务对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean insert(FbsMessage bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据编辑业务对象修改消息
|
||||||
|
* @param bo 消息编辑业务对象
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean update(FbsMessage bo);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 校验并删除数据
|
||||||
|
* @param ids 主键集合
|
||||||
|
* @param isValid 是否校验,true-删除前校验,false-不校验
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分包商的未读消息统计
|
||||||
|
*/
|
||||||
|
FbsMessageCountVO countUnread();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分包商的消息列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<FbsMessageVO> queryMyPageList(FbsMessageMyListDTO dto);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息详情列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<FbsMessageDetailVO> queryDetailPageList(FbsMessageDetailDTO dto);
|
||||||
|
}
|
@ -0,0 +1,207 @@
|
|||||||
|
package com.ruoyi.fbs.service.impl;
|
||||||
|
|
||||||
|
import cn.hutool.core.bean.BeanUtil;
|
||||||
|
import cn.hutool.core.util.StrUtil;
|
||||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
|
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||||
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.common.enums.BgtMessageType;
|
||||||
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
|
import com.ruoyi.common.utils.SecurityUtils;
|
||||||
|
import com.ruoyi.fbs.bo.FbsMessageQueryBo;
|
||||||
|
import com.ruoyi.fbs.domain.FbsMessage;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageDetailDTO;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsMessageMyListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageCountVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageDetailVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsMessageVO;
|
||||||
|
import com.ruoyi.fbs.mapper.FbsMessageMapper;
|
||||||
|
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.OPERATION_NEED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 消息Service业务层处理
|
||||||
|
*
|
||||||
|
* @author ruoyi
|
||||||
|
* @date 2025-03-28
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class FbsMessageServiceImpl extends ServicePlusImpl<FbsMessageMapper, FbsMessage> implements IFbsMessageService {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FbsMessage queryById(Long id){
|
||||||
|
return getById(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<FbsMessage> queryPageList(FbsMessageQueryBo bo) {
|
||||||
|
Page<FbsMessage> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||||
|
return PageUtils.buildDataInfo(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<FbsMessage> queryList(FbsMessageQueryBo bo) {
|
||||||
|
return list(buildQueryWrapper(bo));
|
||||||
|
}
|
||||||
|
|
||||||
|
private LambdaQueryWrapper<FbsMessage> buildQueryWrapper(FbsMessageQueryBo bo) {
|
||||||
|
Map<String, Object> params = bo.getParams();
|
||||||
|
LambdaQueryWrapper<FbsMessage> lqw = Wrappers.lambdaQuery();
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getSenderType()), FbsMessage::getSenderType, bo.getSenderType());
|
||||||
|
lqw.eq(bo.getSenderId() != null, FbsMessage::getSenderId, bo.getSenderId());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getRecipientType()), FbsMessage::getRecipientType, bo.getRecipientType());
|
||||||
|
lqw.eq(bo.getRecipientId() != null, FbsMessage::getRecipientId, bo.getRecipientId());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getHeadline()), FbsMessage::getHeadline, bo.getHeadline());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getSubheading()), FbsMessage::getSubheading, bo.getSubheading());
|
||||||
|
lqw.eq(bo.getTableId() != null, FbsMessage::getTableId, bo.getTableId());
|
||||||
|
lqw.like(StrUtil.isNotBlank(bo.getTableName()), FbsMessage::getTableName, bo.getTableName());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getMessageLargeType()), FbsMessage::getMessageLargeType, bo.getMessageLargeType());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getMessageSmallType()), FbsMessage::getMessageSmallType, bo.getMessageSmallType());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getReadStatus()), FbsMessage::getReadStatus, bo.getReadStatus());
|
||||||
|
lqw.eq(StrUtil.isNotBlank(bo.getIsOperation()), FbsMessage::getIsOperation, bo.getIsOperation());
|
||||||
|
return lqw;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean insert(FbsMessage bo) {
|
||||||
|
FbsMessage add = BeanUtil.toBean(bo, FbsMessage.class);
|
||||||
|
validEntityBeforeSave(add);
|
||||||
|
return save(add);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean update(FbsMessage bo) {
|
||||||
|
FbsMessage update = BeanUtil.toBean(bo, FbsMessage.class);
|
||||||
|
validEntityBeforeSave(update);
|
||||||
|
return updateById(update);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存前的数据校验
|
||||||
|
*
|
||||||
|
* @param entity 实体类数据
|
||||||
|
*/
|
||||||
|
private void validEntityBeforeSave(FbsMessage entity){
|
||||||
|
//TODO 做一些数据校验,如唯一约束
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||||
|
if(isValid){
|
||||||
|
//TODO 做一些业务上的校验,判断是否需要校验
|
||||||
|
}
|
||||||
|
return removeByIds(ids);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public FbsMessageCountVO countUnread() {
|
||||||
|
List<FbsMessage> fbsMessages = baseMapper.selectList(Wrappers.<FbsMessage>lambdaQuery()
|
||||||
|
.eq(FbsMessage::getRecipientId, SecurityUtils.getAppUserId())
|
||||||
|
.eq(FbsMessage::getReadStatus, "0"));
|
||||||
|
Map<String, Long> map = fbsMessages.stream().collect(Collectors.groupingBy(FbsMessage::getMessageLargeType, Collectors.counting()));
|
||||||
|
|
||||||
|
FbsMessageCountVO fbsMessageCountVO = new FbsMessageCountVO();
|
||||||
|
fbsMessageCountVO.setTaskMessageCount(map.getOrDefault(BgtMessageType.TASK.getCode(), 0L).intValue());
|
||||||
|
fbsMessageCountVO.setSettlementMessageCount(map.getOrDefault(BgtMessageType.SETTLEMENT.getCode(), 0L).intValue());
|
||||||
|
fbsMessageCountVO.setOtherMessageCount(map.getOrDefault(BgtMessageType.OTHER.getCode(), 0L).intValue());
|
||||||
|
|
||||||
|
Integer handle = baseMapper.selectCount(Wrappers.<FbsMessage>lambdaQuery()
|
||||||
|
.eq(FbsMessage::getRecipientId, SecurityUtils.getAppUserId())
|
||||||
|
.eq(FbsMessage::getIsOperation, OPERATION_NEED));
|
||||||
|
fbsMessageCountVO.setHandleMessageCount(handle);
|
||||||
|
return fbsMessageCountVO;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<FbsMessageVO> queryMyPageList(FbsMessageMyListDTO dto) {
|
||||||
|
LambdaQueryWrapper<FbsMessage> wrapper = new LambdaQueryWrapper<>();
|
||||||
|
wrapper.eq(FbsMessage::getRecipientId, SecurityUtils.getAppUserId());
|
||||||
|
wrapper.orderByDesc(FbsMessage::getCreateTime);
|
||||||
|
Page<FbsMessage> result = page(PageUtils.buildPage(), wrapper);
|
||||||
|
Page<FbsMessageVO> fbsMessageVOPage = new Page<>();
|
||||||
|
fbsMessageVOPage.setTotal(result.getTotal());
|
||||||
|
fbsMessageVOPage.setRecords(BeanUtil.copyToList(result.getRecords(), FbsMessageVO.class));
|
||||||
|
return PageUtils.buildDataInfo(fbsMessageVOPage);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<FbsMessageDetailVO> queryDetailPageList(FbsMessageDetailDTO dto) {
|
||||||
|
LambdaQueryWrapper<FbsMessage> wrapper = new LambdaQueryWrapper<>();
|
||||||
|
wrapper.eq(FbsMessage::getRecipientId, SecurityUtils.getAppUserId());
|
||||||
|
wrapper.eq(StrUtil.isNotBlank(dto.getMessageLargeType()), FbsMessage::getMessageLargeType, dto.getMessageLargeType());
|
||||||
|
wrapper.eq(StrUtil.isNotBlank(dto.getMessageSmallType()), FbsMessage::getMessageSmallType, dto.getMessageSmallType());
|
||||||
|
wrapper.eq(dto.getIsHandle(), FbsMessage::getIsOperation,OPERATION_NEED);
|
||||||
|
if(dto.getDate() != null) {
|
||||||
|
wrapper.between(FbsMessage::getCreateTime, dto.getDate().atStartOfDay(), dto.getDate().atStartOfDay().with(LocalTime.MAX));
|
||||||
|
}
|
||||||
|
wrapper.orderByDesc(FbsMessage::getId);
|
||||||
|
Page<FbsMessage> result = page(PageUtils.buildPage(), wrapper);
|
||||||
|
Page<FbsMessageDetailVO> page = new Page<>();
|
||||||
|
page.setTotal(result.getTotal());
|
||||||
|
|
||||||
|
ArrayList<FbsMessageDetailVO> fbsMessageDetailVOS = new ArrayList<>();
|
||||||
|
|
||||||
|
for (FbsMessage message : result.getRecords()) {
|
||||||
|
FbsMessageDetailVO fbsMessageDetailVO = BeanUtil.copyProperties(message, FbsMessageDetailVO.class);
|
||||||
|
// if (BGT_LARGE_TASK.equals(message.getMessageLargeType())) {
|
||||||
|
// FbsProjectTask task = taskService.getById(message.getTableId());
|
||||||
|
// bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||||
|
// } else if (BGT_LARGE_SETTLEMENT.equals(message.getMessageLargeType())) {
|
||||||
|
// BgtWageApplication wageApplication = wageApplicationService.getById(message.getTableId());
|
||||||
|
// FbsProjectTask task = taskService.getById(wageApplication.getTaskId());
|
||||||
|
// bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||||
|
// } else if (BGT_LARGE_OTHER.equals(message.getMessageLargeType())) {
|
||||||
|
// switch (message.getMessageSmallType()) {
|
||||||
|
// case BGT_SMALL_SIGN_UP:
|
||||||
|
// BgtProjectRecruitApply recruitApply = recruitApplyService.getById(message.getTableId());
|
||||||
|
// BgtProjectRecruit recruit = recruitService.getById(recruitApply.getRecruitId());
|
||||||
|
// bgtMessageDetailVO.setRecruitName(recruit.getRecruitName());
|
||||||
|
// break;
|
||||||
|
// case BGT_SMALL_PAY:
|
||||||
|
// WgzPayCalculation payCalculation = payCalculationService.getById(message.getTableId());
|
||||||
|
// BgtProjectRecruit recruitPay = recruitService.getById(payCalculation.getRecruitId());
|
||||||
|
// bgtMessageDetailVO.setRecruitName(recruitPay.getRecruitName());
|
||||||
|
// break;
|
||||||
|
// case BGT_SMALL_LEAVE:
|
||||||
|
// WgzLeave wgzLeave = leaveService.getById(message.getTableId());
|
||||||
|
// bgtMessageDetailVO.setReason(wgzLeave.getReason());
|
||||||
|
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(wgzLeave.getUserId()).getUsername());
|
||||||
|
// bgtMessageDetailVO.setStartTime(wgzLeave.getStartTime());
|
||||||
|
// bgtMessageDetailVO.setEndTime(wgzLeave.getEndTime());
|
||||||
|
// break;
|
||||||
|
// case BGT_SMALL_MAKE_UP:
|
||||||
|
// WgzReissueacard reissueCard = reissueacardService.getById(message.getTableId());
|
||||||
|
// bgtMessageDetailVO.setReason(reissueCard.getReason());
|
||||||
|
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(reissueCard.getUserId()).getUsername());
|
||||||
|
// bgtMessageDetailVO.setNowTime(reissueCard.getNowTime());
|
||||||
|
// break;
|
||||||
|
// case BGT_SMALL_REPORT_MAKE_UP:
|
||||||
|
// WgzDailyClock dailyClock = dailyClockService.getById(message.getTableId());
|
||||||
|
// BgtProjectRecruit recruitClock = recruitService.getById(dailyClock.getRecruitId());
|
||||||
|
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(dailyClock.getUserId()).getUsername());
|
||||||
|
// bgtMessageDetailVO.setRecruitName(recruitClock.getRecruitName());
|
||||||
|
// break;
|
||||||
|
// default:
|
||||||
|
// break;
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
fbsMessageDetailVOS.add(fbsMessageDetailVO);
|
||||||
|
}
|
||||||
|
page.setRecords(fbsMessageDetailVOS);
|
||||||
|
return PageUtils.buildDataInfo(page);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -1,9 +1,6 @@
|
|||||||
package com.ruoyi.zbf.domain;
|
package com.ruoyi.zbf.domain;
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
import com.baomidou.mybatisplus.annotation.*;
|
||||||
import com.baomidou.mybatisplus.annotation.TableField;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableId;
|
|
||||||
import com.baomidou.mybatisplus.annotation.TableName;
|
|
||||||
import com.ruoyi.common.annotation.Excel;
|
import com.ruoyi.common.annotation.Excel;
|
||||||
import io.swagger.annotations.ApiModel;
|
import io.swagger.annotations.ApiModel;
|
||||||
import io.swagger.annotations.ApiModelProperty;
|
import io.swagger.annotations.ApiModelProperty;
|
||||||
@ -31,7 +28,7 @@ public class ZbfProjectSubcontractingApply implements Serializable {
|
|||||||
|
|
||||||
/** 主键ID */
|
/** 主键ID */
|
||||||
@ApiModelProperty("主键ID")
|
@ApiModelProperty("主键ID")
|
||||||
@TableId(value = "id")
|
@TableId(value = "id", type = IdType.AUTO)
|
||||||
private Long id;
|
private Long id;
|
||||||
|
|
||||||
/** 项目ID */
|
/** 项目ID */
|
||||||
|
@ -1,10 +1,14 @@
|
|||||||
package com.ruoyi.zbf.mapper;
|
package com.ruoyi.zbf.mapper;
|
||||||
|
|
||||||
|
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||||
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsProjectSectionListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO;
|
||||||
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
||||||
import org.apache.ibatis.annotations.CacheNamespace;
|
import org.apache.ibatis.annotations.CacheNamespace;
|
||||||
|
import org.apache.ibatis.annotations.Param;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 总包方项目标段Mapper接口
|
* 总包方项目标段Mapper接口
|
||||||
@ -16,4 +20,7 @@ import org.apache.ibatis.annotations.CacheNamespace;
|
|||||||
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
||||||
public interface ZbfProjectSectionMapper extends BaseMapperPlus<ZbfProjectSection> {
|
public interface ZbfProjectSectionMapper extends BaseMapperPlus<ZbfProjectSection> {
|
||||||
|
|
||||||
|
// 查询分包商已加入的项目标段
|
||||||
|
Page<FbsProjectSectionListVO> joinSectionList(@Param("page") Page<FbsProjectSectionListDTO> page, @Param("dto") FbsProjectSectionListDTO dto);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,8 @@ package com.ruoyi.zbf.service;
|
|||||||
|
|
||||||
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsProjectSectionListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO;
|
||||||
import com.ruoyi.zbf.bo.ZbfProjectSectionQueryBo;
|
import com.ruoyi.zbf.bo.ZbfProjectSectionQueryBo;
|
||||||
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
||||||
|
|
||||||
@ -53,4 +55,10 @@ public interface IZbfProjectSectionService extends IServicePlus<ZbfProjectSectio
|
|||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分包商查询自己的项目分包列表
|
||||||
|
*/
|
||||||
|
TableDataInfo<FbsProjectSectionListVO> fbsSubList(FbsProjectSectionListDTO dto) ;
|
||||||
}
|
}
|
||||||
|
@ -8,12 +8,20 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|||||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||||
import com.ruoyi.common.core.page.TableDataInfo;
|
import com.ruoyi.common.core.page.TableDataInfo;
|
||||||
import com.ruoyi.common.utils.PageUtils;
|
import com.ruoyi.common.utils.PageUtils;
|
||||||
|
import com.ruoyi.common.utils.SecurityUtils;
|
||||||
|
import com.ruoyi.fbs.domain.dto.FbsProjectSectionListDTO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO;
|
||||||
|
import com.ruoyi.fbs.domain.vo.FbsProjectSubcontractingListVO;
|
||||||
import com.ruoyi.zbf.bo.ZbfProjectSectionQueryBo;
|
import com.ruoyi.zbf.bo.ZbfProjectSectionQueryBo;
|
||||||
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
||||||
|
import com.ruoyi.zbf.domain.ZbfProjectSubcontracting;
|
||||||
import com.ruoyi.zbf.mapper.ZbfProjectSectionMapper;
|
import com.ruoyi.zbf.mapper.ZbfProjectSectionMapper;
|
||||||
import com.ruoyi.zbf.service.IZbfProjectSectionService;
|
import com.ruoyi.zbf.service.IZbfProjectSectionService;
|
||||||
|
import com.ruoyi.zbf.service.IZbfProjectSubcontractingService;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -27,6 +35,9 @@ import java.util.Map;
|
|||||||
@Service
|
@Service
|
||||||
public class ZbfProjectSectionServiceImpl extends ServicePlusImpl<ZbfProjectSectionMapper, ZbfProjectSection> implements IZbfProjectSectionService {
|
public class ZbfProjectSectionServiceImpl extends ServicePlusImpl<ZbfProjectSectionMapper, ZbfProjectSection> implements IZbfProjectSectionService {
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
private IZbfProjectSubcontractingService zbfProjectSubcontractingService;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ZbfProjectSection queryById(Long id){
|
public ZbfProjectSection queryById(Long id){
|
||||||
return getById(id);
|
return getById(id);
|
||||||
@ -82,4 +93,31 @@ public class ZbfProjectSectionServiceImpl extends ServicePlusImpl<ZbfProjectSect
|
|||||||
}
|
}
|
||||||
return removeByIds(ids);
|
return removeByIds(ids);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TableDataInfo<FbsProjectSectionListVO> fbsSubList(FbsProjectSectionListDTO dto) {
|
||||||
|
Page<FbsProjectSectionListDTO> queryDTOPage = new Page<>();
|
||||||
|
queryDTOPage.setCurrent(dto.getPageNum());
|
||||||
|
queryDTOPage.setSize(dto.getPageSize());
|
||||||
|
dto.setFbsUserId(SecurityUtils.getAppUserId());
|
||||||
|
Page<FbsProjectSectionListVO> queryVOPage = baseMapper.joinSectionList(queryDTOPage, dto);
|
||||||
|
|
||||||
|
for (FbsProjectSectionListVO sectionListVO : queryVOPage.getRecords()){
|
||||||
|
//分包处理
|
||||||
|
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||||
|
//查询标段下的所有已承接的分包
|
||||||
|
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||||
|
.eq(ZbfProjectSubcontracting::getSectionId, sectionListVO.getId())
|
||||||
|
.eq(ZbfProjectSubcontracting::getUserId, SecurityUtils.getAppUserId()));
|
||||||
|
|
||||||
|
for (ZbfProjectSubcontracting sub : subList){
|
||||||
|
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||||
|
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||||
|
subListVO.add(fbsProjectSubcontractingListVO);
|
||||||
|
}
|
||||||
|
sectionListVO.setSubList(subListVO);
|
||||||
|
}
|
||||||
|
|
||||||
|
return PageUtils.buildDataInfo(queryVOPage);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
bwa.task_staff_num,
|
bwa.task_staff_num,
|
||||||
bwa.task_address,
|
bwa.task_address,
|
||||||
bwa.applicant_amount,
|
bwa.applicant_amount,
|
||||||
bwa.create_time,
|
bwa.apply_time,
|
||||||
bwa.id,
|
bwa.id,
|
||||||
bwa.username,
|
bwa.username,
|
||||||
bwa.project_name,
|
bwa.project_name,
|
||||||
@ -73,5 +73,34 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
order by bwa.create_time desc
|
order by bwa.create_time desc
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
<select id="fbsAuditPageList" resultType="com.ruoyi.bgt.domain.vo.BgtWageApplicationVO">
|
||||||
|
select bwa.task_name,
|
||||||
|
bwa.task_staff_num,
|
||||||
|
bwa.task_address,
|
||||||
|
bwa.applicant_amount,
|
||||||
|
bwa.apply_time,
|
||||||
|
bwa.id,
|
||||||
|
bwa.username,
|
||||||
|
bwa.project_name,
|
||||||
|
bwa.audit_status
|
||||||
|
from bgt_wage_application bwa
|
||||||
|
<where>
|
||||||
|
<if test="dto.reviewerId != null ">
|
||||||
|
and bwa.reviewer_id = #{dto.reviewerId}
|
||||||
|
</if>
|
||||||
|
<if test="dto.taskId != null ">
|
||||||
|
and bwa.task_id = #{dto.taskId}
|
||||||
|
</if>
|
||||||
|
<if test="dto.taskName != null and dto.taskName != ''">
|
||||||
|
and bpr.task_name like concat('%', #{dto.taskName}, '%')
|
||||||
|
</if>
|
||||||
|
<if test="dto.type != null and dto.type == 1 ">
|
||||||
|
and bwa.audit_status = '1'
|
||||||
|
</if>
|
||||||
|
<if test="dto.type != null and dto.type == 2 ">
|
||||||
|
and bwa.audit_status in ('2','3')
|
||||||
|
</if>
|
||||||
|
</where>
|
||||||
|
</select>
|
||||||
|
|
||||||
</mapper>
|
</mapper>
|
||||||
|
@ -0,0 +1,30 @@
|
|||||||
|
<?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.ruoyi.fbs.mapper.FbsMessageMapper">
|
||||||
|
|
||||||
|
<resultMap type="com.ruoyi.fbs.domain.FbsMessage" id="FbsMessageResult">
|
||||||
|
<result property="id" column="id"/>
|
||||||
|
<result property="senderType" column="sender_type"/>
|
||||||
|
<result property="senderId" column="sender_id"/>
|
||||||
|
<result property="recipientType" column="recipient_type"/>
|
||||||
|
<result property="recipientId" column="recipient_id"/>
|
||||||
|
<result property="headline" column="headline"/>
|
||||||
|
<result property="subheading" column="subheading"/>
|
||||||
|
<result property="tableId" column="table_id"/>
|
||||||
|
<result property="tableName" column="table_name"/>
|
||||||
|
<result property="messageLargeType" column="message_large_type"/>
|
||||||
|
<result property="messageSmallType" column="message_small_type"/>
|
||||||
|
<result property="readStatus" column="read_status"/>
|
||||||
|
<result property="delFlag" column="del_flag"/>
|
||||||
|
<result property="createBy" column="create_by"/>
|
||||||
|
<result property="createTime" column="create_time"/>
|
||||||
|
<result property="updateBy" column="update_by"/>
|
||||||
|
<result property="updateTime" column="update_time"/>
|
||||||
|
<result property="remark" column="remark"/>
|
||||||
|
<result property="isOperation" column="is_operation"/>
|
||||||
|
</resultMap>
|
||||||
|
|
||||||
|
|
||||||
|
</mapper>
|
@ -67,7 +67,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
<if test="dto.auditorType != null and dto.auditorType != ''">
|
<if test="dto.auditorType != null and dto.auditorType != ''">
|
||||||
and a.auditor_type = #{dto.auditorType}
|
and a.auditor_type = #{dto.auditorType}
|
||||||
</if>
|
</if>
|
||||||
<if test="dto.auditorType == null">
|
<if test="dto.auditorType == null or dto.auditorType == ''">
|
||||||
and a.auditor_type in (0,1,2,3)
|
and a.auditor_type in (0,1,2,3)
|
||||||
</if>
|
</if>
|
||||||
<if test="dto.date != null">
|
<if test="dto.date != null">
|
||||||
|
@ -17,5 +17,18 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|||||||
<result property="remark" column="remark"/>
|
<result property="remark" column="remark"/>
|
||||||
</resultMap>
|
</resultMap>
|
||||||
|
|
||||||
|
<select id="joinSectionList" resultType="com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO">
|
||||||
|
SELECT zps.id, zps.project_id, zps.section_name
|
||||||
|
from zbf_project_section zps
|
||||||
|
left join zbf_project zp on zps.project_id = zp.id
|
||||||
|
where EXISTS (SELECT 1
|
||||||
|
FROM zbf_project_subcontracting zpsu
|
||||||
|
WHERE zpsu.user_id = #{dto.fbsUserId}
|
||||||
|
AND zps.id = zpsu.section_id)
|
||||||
|
<if test="dto.projectId!=null">
|
||||||
|
and zps.project_id = #{dto.projectId}
|
||||||
|
</if>
|
||||||
|
|
||||||
|
</select>
|
||||||
|
|
||||||
</mapper>
|
</mapper>
|
||||||
|
BIN
ruoyi/uploadPath/appResource/recruitDefault.png
Normal file
BIN
ruoyi/uploadPath/appResource/recruitDefault.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.1 MiB |
Reference in New Issue
Block a user