zqy
2025-09-21 bd2df0a3e0634bb5469472f10315797365748559
archiveManager/src/main/java/com/ruoyi/service/impl/ArchiverecordstouserServiceImpl.java
@@ -1,8 +1,10 @@
package com.ruoyi.service.impl;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.stream.Collectors;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -12,16 +14,19 @@
import com.ruoyi.common.utils.MapUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.domain.ArchiveRecords;
import com.ruoyi.domain.Archiverecordstouser;
import com.ruoyi.domain.vo.RecordToUserCount;
import com.ruoyi.mapper.ArchiverecordstouserMapper;
import com.ruoyi.service.IArchiverecordstouserService;
import com.ruoyi.system.mapper.SysUserMapper;
import com.ruoyi.system.service.ISysUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
 * 【请填写功能名称】Service业务层处理
 * 【档案分配】Service业务层处理
 * 
 * @author ruoyi
 * @date 2025-07-20
@@ -31,17 +36,34 @@
{
  @Autowired
    private SysUserMapper userMapper;
  @Autowired
  private ISysUserService iSysUserService;
    private LambdaQueryWrapper<Archiverecordstouser> buildCondition(Archiverecordstouser archiverecordstouser) {
        LambdaQueryWrapper<Archiverecordstouser> lqw = new LambdaQueryWrapper<>();
        lqw.eq(!StringUtils.isEmpty(archiverecordstouser.getArchiveRecordsId()),Archiverecordstouser::getArchiveRecordsId, archiverecordstouser.getArchiveRecordsId());
        //保存相关用户的userId
        List<Long> arr = new ArrayList<>();
        List<SysUser> all = new ArrayList<>();
        if(!StringUtils.isEmpty(archiverecordstouser.getUserName())||!StringUtils.isEmpty(archiverecordstouser.getPhonenumber()))
        {
            //根据用户名查询用户相关id
            SysUser sysUser = new SysUser();
            sysUser.setUserName(archiverecordstouser.getUserName());
            sysUser.setPhonenumber(archiverecordstouser.getPhonenumber());
            all = userMapper.selectUserList(sysUser);
        }
        arr = all.stream().map(SysUser::getUserId).collect(Collectors.toList());
        lqw.in(!all.isEmpty(), Archiverecordstouser::getUserId, arr);
      //  System.out.println(archiverecordstouser.getSysUser().getUserName()+"098643");
        return lqw;
    }
    @Override
    public int insertRecordToUsers(String recordId, Long[] userIds) {
        // 新增用户与角色管理
        // 新增用户与案卷记录
        List<Archiverecordstouser> list = new ArrayList<Archiverecordstouser>();
        for (Long userId : userIds)
        {
@@ -49,6 +71,7 @@
            ur.setArchiveRecordsId(recordId);
            ur.setUserId(userId);
            list.add(ur);
            break;
        }
        boolean res =  this.saveBatch(list);
        if(res)
@@ -86,10 +109,10 @@
        return AjaxResult.success(data);    }
    /**
     * 查询【请填写功能名称】
     * 查询【档案分配】
     * 
     * @param id 【请填写功能名称】主键
     * @return 【请填写功能名称】
     * @param id 【档案分配】主键
     * @return 【档案分配】
     */
    @Override
    public Archiverecordstouser selectArchiverecordstouserById(Long id)
@@ -98,22 +121,30 @@
    }
    @Override
    public boolean selectArchiveRecordUsers(String recordId) {
        LambdaQueryWrapper<Archiverecordstouser> lqw = new LambdaQueryWrapper<>();
        lqw.eq(!StringUtils.isEmpty(recordId),Archiverecordstouser::getArchiveRecordsId, recordId);
        List<Archiverecordstouser> lis = list(lqw);
        return !lis.isEmpty();
    }
    @Override
    public List<Archiverecordstouser> selectArchiverecordstouserList(Archiverecordstouser archiverecordstouser) {
        return null;
        return this.list();
    }
    /**
     * 查询【请填写功能名称】列表
     * 查询【档案分配】列表
     * 
     * @param archiverecordstouser 【请填写功能名称】
     * @return 【请填写功能名称】
     * @param archiverecordstouser 【档案分配】
     * @return 【档案分配】
     */
    /**
     * 新增【请填写功能名称】
     * 新增【档案分配】
     * 
     * @param archiverecordstouser 【请填写功能名称】
     * @param archiverecordstouser 【档案分配】
     * @return 结果
     */
    @Override
@@ -123,9 +154,9 @@
    }
    /**
     * 修改【请填写功能名称】
     * 修改【档案分配】
     * 
     * @param archiverecordstouser 【请填写功能名称】
     * @param archiverecordstouser 【档案分配】
     * @return 结果
     */
    @Override
@@ -135,9 +166,9 @@
    }
    /**
     * 批量删除【请填写功能名称】
     * 批量删除【档案分配】
     * 
     * @param ids 需要删除的【请填写功能名称】主键
     * @param ids 需要删除的【档案分配】主键
     * @return 结果
     */
    @Override
@@ -147,9 +178,9 @@
    }
    /**
     * 删除【请填写功能名称】信息
     * 删除【档案分配】信息
     * 
     * @param id 【请填写功能名称】主键
     * @param id 【档案分配】主键
     * @return 结果
     */
    @Override
@@ -157,4 +188,60 @@
    {
        return 0;
    }
    @Override
    public int deleteArchiverecordstouserByRecordId(String recordId, Long userId) {
        LambdaQueryWrapper<Archiverecordstouser> lqw = new LambdaQueryWrapper<>();
        lqw.eq(!StringUtils.isEmpty(recordId), Archiverecordstouser::getArchiveRecordsId, recordId)
                .eq(userId!=null, Archiverecordstouser::getUserId, userId);
        if(this.remove(lqw))
            return 1;
        else
            return 0;
    }
    @Override
    public int queryArchiverecordstouserByRecordId(String recordId, Long userId) {
        LambdaQueryWrapper<Archiverecordstouser> lqw = new LambdaQueryWrapper<>();
        lqw.eq(!StringUtils.isEmpty(recordId), Archiverecordstouser::getArchiveRecordsId, recordId)
                .eq(userId!=null, Archiverecordstouser::getUserId, userId);
        List<Archiverecordstouser> lis = list(lqw);
        if(!lis.isEmpty())
            return 1;
        else
            return 0;
    }
    @Override
    public AjaxResult countStatistic(String username, int pageNum, int pageSize) {
        LambdaQueryWrapper<RecordToUserCount> lqw = new LambdaQueryWrapper<>();
        if(username!=null)
            lqw.like(!StringUtils.isEmpty(username), RecordToUserCount::getUserName, username);
        Page<RecordToUserCount> page = new Page<>(pageNum, pageSize);
        // 使用自定义的分页查询方法,先连接再分页
        Page<RecordToUserCount> pageResult = this.baseMapper.selectRecordToUserPage(page, lqw);
        List<RecordToUserCount> beanRecords = pageResult.getRecords();//得到查询出来的数据
        HashMap<String, Object> data = MapUtils.getResult(pageResult, beanRecords);
        return AjaxResult.success(data);
    }
    @Override
    public List<RecordToUserCount> findAllRecordToUserCont() {
        return this.baseMapper.selectRecordToUserAll();
    }
}