fix(工作台): 我的待办缺陷列表状态过滤有误
--bug=1032808 --user=宋昌昌 【工作台】集成local-我的待办-缺陷管理-已关闭状态仍在我的待办列表显示 https://www.tapd.cn/55049933/s/1435662
This commit is contained in:
parent
bcaced6e6e
commit
0039825318
|
@ -73,4 +73,8 @@ public class IssuesRequest extends BaseQueryRequest {
|
|||
* 过滤缺陷ID
|
||||
*/
|
||||
private List<String> filterIds;
|
||||
/**
|
||||
* Local平台的状态自定义字段ID
|
||||
*/
|
||||
private String statusFieldId;
|
||||
}
|
||||
|
|
|
@ -216,6 +216,7 @@
|
|||
<property name="condition" value="request.combine"/>
|
||||
<property name="name" value="request.name"/>
|
||||
<property name="objectKey" value="request.combine.tags"/>
|
||||
<property name="statusFieldId" value="request.statusFieldId"/>
|
||||
</include>
|
||||
</if>
|
||||
<if test="request.name != null">
|
||||
|
@ -361,11 +362,14 @@
|
|||
)
|
||||
or
|
||||
(
|
||||
issues.platform = 'Local' and
|
||||
issues.status
|
||||
<include refid="condition">
|
||||
<property name="object" value="${condition}.doneStatus"/>
|
||||
</include>
|
||||
issues.platform = 'Local' and issues.id in
|
||||
(
|
||||
select resource_id from custom_field_issues where field_id = #{${statusFieldId}}
|
||||
and trim(both '"' from value)
|
||||
<include refid="condition">
|
||||
<property name="object" value="${condition}.doneStatus"/>
|
||||
</include>
|
||||
)
|
||||
)
|
||||
)
|
||||
</if>
|
||||
|
|
|
@ -32,13 +32,13 @@ import io.metersphere.service.PlatformPluginService;
|
|||
import io.metersphere.xpack.track.dto.*;
|
||||
import io.metersphere.xpack.track.dto.request.IssuesRequest;
|
||||
import io.metersphere.xpack.track.dto.request.IssuesUpdateRequest;
|
||||
import jakarta.annotation.Resource;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import org.apache.commons.collections.CollectionUtils;
|
||||
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.web.multipart.MultipartFile;
|
||||
|
||||
import jakarta.annotation.Resource;
|
||||
import jakarta.servlet.http.HttpServletResponse;
|
||||
import java.util.Collections;
|
||||
import java.util.List;
|
||||
|
||||
|
@ -58,7 +58,7 @@ public class IssuesController {
|
|||
@PostMapping("/list/{goPage}/{pageSize}")
|
||||
@RequiresPermissions(PermissionConstants.PROJECT_TRACK_ISSUE_READ)
|
||||
public Pager<List<IssuesDao>> list(@PathVariable int goPage, @PathVariable int pageSize, @RequestBody IssuesRequest request) {
|
||||
issuesService.setFilterIds(request);
|
||||
issuesService.setFilterParam(request);
|
||||
if (request.getThisWeekUnClosedTestPlanIssue() && CollectionUtils.isEmpty(request.getFilterIds())) {
|
||||
Page<List<Issues>> page = PageHelper.startPage(goPage, pageSize, true);
|
||||
return PageUtils.setPageInfo(page, Collections.EMPTY_LIST);
|
||||
|
|
|
@ -11,13 +11,13 @@ import io.metersphere.commons.utils.SubListUtil;
|
|||
import io.metersphere.constants.SystemCustomField;
|
||||
import io.metersphere.dto.CustomFieldDao;
|
||||
import io.metersphere.dto.CustomFieldResourceDTO;
|
||||
import jakarta.annotation.Resource;
|
||||
import org.apache.ibatis.session.SqlSession;
|
||||
import org.apache.ibatis.session.SqlSessionFactory;
|
||||
import org.mybatis.spring.SqlSessionUtils;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import jakarta.annotation.Resource;
|
||||
import java.util.*;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
|
@ -73,7 +73,7 @@ public class CustomFieldIssuesService extends CustomFieldResourceService {
|
|||
if (customFieldMap == null || customFieldMap.size() == 0) {
|
||||
return;
|
||||
}
|
||||
this.checkInit();
|
||||
checkInit();
|
||||
SqlSession sqlSession = ServiceUtils.getBatchSqlSession();
|
||||
BaseCustomFieldResourceMapper batchMapper = sqlSession.getMapper(BaseCustomFieldResourceMapper.class);
|
||||
List<CustomFieldResourceDTO> addList = new ArrayList<>();
|
||||
|
|
|
@ -2067,7 +2067,7 @@ public class IssuesService {
|
|||
});
|
||||
}
|
||||
|
||||
public void setFilterIds(IssuesRequest request) {
|
||||
public void setFilterParam(IssuesRequest request) {
|
||||
List<String> issueIds;
|
||||
if (request.getThisWeekUnClosedTestPlanIssue()) {
|
||||
Map<String, Date> weedFirstTimeAndLastTime = io.metersphere.commons.utils.DateUtils.getWeedFirstTimeAndLastTime(new Date());
|
||||
|
@ -2105,6 +2105,13 @@ public class IssuesService {
|
|||
request.setFilterIds(issueIds);
|
||||
}
|
||||
}
|
||||
|
||||
// 状态过滤时, 设置自定义状态字段ID
|
||||
Project project = projectMapper.selectByPrimaryKey(request.getProjectId());
|
||||
if (StringUtils.equals(project.getPlatform(), "Local")) {
|
||||
CustomField statusField = baseCustomFieldService.getCustomFieldByName(request.getProjectId(), SystemCustomField.ISSUE_STATUS);
|
||||
request.setStatusFieldId(statusField.getId());
|
||||
}
|
||||
}
|
||||
|
||||
public boolean thirdPartTemplateEnable(String projectId) {
|
||||
|
|
Loading…
Reference in New Issue