weaver-hrm-salary/src/com/engine/salary/service/SalarySobService.java

154 lines
3.7 KiB
Java
Raw Normal View History

2022-03-16 14:29:02 +08:00
package com.engine.salary.service;
import com.engine.salary.entity.salarysob.dto.SalarySobCycleDTO;
2022-05-31 16:41:11 +08:00
import com.engine.salary.entity.salarysob.param.SalarySobBasicSaveParam;
2022-03-16 14:29:02 +08:00
import com.engine.salary.entity.salarysob.param.SalarySobDisableParam;
import com.engine.salary.entity.salarysob.param.SalarySobDuplicateParam;
2022-05-31 16:41:11 +08:00
import com.engine.salary.entity.salarysob.param.SalarySobListQueryParam;
2022-03-16 14:29:02 +08:00
import com.engine.salary.entity.salarysob.po.SalarySobPO;
import com.engine.salary.enums.salarysob.IncomeCategoryEnum;
2022-05-31 16:41:11 +08:00
import com.engine.salary.util.page.PageInfo;
2022-03-16 14:29:02 +08:00
import java.time.YearMonth;
import java.util.Collection;
import java.util.List;
/**
2022-05-26 11:02:55 +08:00
* 薪资账套
* <p>Copyright: Copyright (c) 2022</p>
* <p>Company: 泛微软件</p>
*
* @author qiantao
* @version 1.0
**/
2022-03-16 14:29:02 +08:00
public interface SalarySobService {
/**
* 根据主键id获取单个薪资账套
*
* @param id 主键id
* @return
*/
2022-03-22 21:01:38 +08:00
SalarySobPO getById(Long id);
2022-03-16 14:29:02 +08:00
/**
* 根据主键id查询薪资账套
*
* @param ids 主键id
* @return
*/
2022-03-22 21:01:38 +08:00
List<SalarySobPO> listByIds(Collection<Long> ids);
2022-03-16 14:29:02 +08:00
/**
* 根据名称精确匹配查询薪资账套
*
* @param name 薪资账套名称
* @return
*/
2022-03-22 21:01:38 +08:00
List<SalarySobPO> listByName(String name);
2022-03-16 14:29:02 +08:00
/**
* 根据名称模糊匹配查询薪资账套
*
* @param nameLike 薪资账套名称
* @return
*/
2022-03-22 21:01:38 +08:00
List<SalarySobPO> listByNameLike(String nameLike);
2022-03-16 14:29:02 +08:00
/**
* 查询启用/禁用的薪资账套
*
* @param disable 启用/禁用
* @return
*/
2022-03-22 21:01:38 +08:00
List<SalarySobPO> listByDisable(Integer disable);
2022-03-16 14:29:02 +08:00
2022-06-07 15:43:22 +08:00
/**
* 获取拥有管理权限的账套
* @return
*/
List<SalarySobPO> listByAdmin();
List<SalarySobPO> listByTaxAgentId(Long taxAgentId);
2022-03-16 14:29:02 +08:00
/**
* 根据薪资类型查询薪资账套
*
* @param incomeCategory 薪资类型
* @return
*/
2022-03-22 21:01:38 +08:00
List<SalarySobPO> listByIncomeCategory(IncomeCategoryEnum incomeCategory);
2022-03-16 14:29:02 +08:00
/**
* 根据列表查询参数查询薪资账套分页
*
* @param queryParam 列表查询参数
* @return
*/
2022-05-31 16:41:11 +08:00
PageInfo<SalarySobPO> listPageByParam(SalarySobListQueryParam queryParam);
2022-03-16 14:29:02 +08:00
2022-06-01 21:15:48 +08:00
List<SalarySobPO> listByParam(SalarySobListQueryParam queryParam);
2022-03-16 14:29:02 +08:00
/**
* 保存
*
* @param saveParam 保存参数
* @return
*/
2022-03-22 21:01:38 +08:00
Long save(SalarySobBasicSaveParam saveParam);
2022-03-16 14:29:02 +08:00
/**
* 编辑
*
* @param saveParam 更新参数
* @return
*/
2022-03-22 21:01:38 +08:00
Long update(SalarySobBasicSaveParam saveParam);
2022-03-16 14:29:02 +08:00
/**
* 更新薪资账套的是否启用
*
* @param disableParam 更新参数
*/
2022-03-22 21:01:38 +08:00
void updateDisable(SalarySobDisableParam disableParam);
2022-03-16 14:29:02 +08:00
/**
* 根据主键id删除
*
* @param ids 薪资账套的主键id
*/
2022-03-22 21:01:38 +08:00
void deleteByIds(Collection<Long> ids);
2022-03-16 14:29:02 +08:00
/**
* 复制
*
* @param duplicateParam 复制参数
*/
2022-03-22 21:01:38 +08:00
void duplicate(SalarySobDuplicateParam duplicateParam);
2022-03-16 14:29:02 +08:00
/**
* 根据薪资所属月计算出薪资账套的薪资周期考勤周期的具体日期范围以及税款所属期福利台账月份的具体月份
*
* @param id 薪资账套的id
* @param salaryMonth 薪资所属月
* @return
*/
SalarySobCycleDTO getSalarySobCycle(Long id, YearMonth salaryMonth);
2022-05-31 16:41:11 +08:00
/**
* 按权限过滤掉无权限的薪资账套
*
2022-06-07 15:43:22 +08:00
* 总管理员拥有权限
2022-05-31 16:41:11 +08:00
* @param salarySobPOS
* @return
*/
List<SalarySobPO> filterByAuthority(List<SalarySobPO> salarySobPOS);
2022-06-07 15:43:22 +08:00
2022-06-20 19:39:01 +08:00
/**
* 根据扣缴义务人查询
* @param taxAgentIds
* @return
*/
List<SalarySobPO> listByTaxAgentIds(Collection<Long> taxAgentIds);
2022-03-16 14:29:02 +08:00
}