feat: 1.15 缺陷管理 我的关注 关注
This commit is contained in:
parent
9f474841c7
commit
0926947cb8
|
@ -142,7 +142,14 @@
|
||||||
<property name="object" value="${condition}.creator"/>
|
<property name="object" value="${condition}.creator"/>
|
||||||
</include>
|
</include>
|
||||||
</if>
|
</if>
|
||||||
|
<if test="${condition}.followPeople != null">
|
||||||
|
and issues.id in (
|
||||||
|
select issue_id from issue_follow where follow_id
|
||||||
|
<include refid="io.metersphere.base.mapper.ext.ExtBaseMapper.condition">
|
||||||
|
<property name="object" value="${condition}.followPeople"/>
|
||||||
|
</include>
|
||||||
|
)
|
||||||
|
</if>
|
||||||
</sql>
|
</sql>
|
||||||
<sql id="condition">
|
<sql id="condition">
|
||||||
<choose>
|
<choose>
|
||||||
|
|
|
@ -129,4 +129,8 @@ public class IssuesController {
|
||||||
return issuesService.getCountByStatus(request);
|
return issuesService.getCountByStatus(request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GetMapping("/follow/{issueId}")
|
||||||
|
public List<String> getFollows(@PathVariable String issueId) {
|
||||||
|
return issuesService.getFollows(issueId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,4 +24,6 @@ public class IssuesUpdateRequest extends IssuesWithBLOBs {
|
||||||
*/
|
*/
|
||||||
private List<String> zentaoBuilds;
|
private List<String> zentaoBuilds;
|
||||||
private List<String> testCaseIds;
|
private List<String> testCaseIds;
|
||||||
|
|
||||||
|
private List<String> follows;
|
||||||
}
|
}
|
||||||
|
|
|
@ -76,6 +76,8 @@ public class IssuesService {
|
||||||
private TestCaseIssueService testCaseIssueService;
|
private TestCaseIssueService testCaseIssueService;
|
||||||
@Resource
|
@Resource
|
||||||
private TestPlanTestCaseService testPlanTestCaseService;
|
private TestPlanTestCaseService testPlanTestCaseService;
|
||||||
|
@Resource
|
||||||
|
private IssueFollowMapper issueFollowMapper;
|
||||||
|
|
||||||
public void testAuth(String workspaceId, String platform) {
|
public void testAuth(String workspaceId, String platform) {
|
||||||
IssuesRequest issuesRequest = new IssuesRequest();
|
IssuesRequest issuesRequest = new IssuesRequest();
|
||||||
|
@ -93,6 +95,7 @@ public class IssuesService {
|
||||||
issuesRequest.getTestCaseIds().forEach(l -> {
|
issuesRequest.getTestCaseIds().forEach(l -> {
|
||||||
testCaseIssueService.updateIssuesCount(l);
|
testCaseIssueService.updateIssuesCount(l);
|
||||||
});
|
});
|
||||||
|
saveFollows(issuesRequest.getId(), issuesRequest.getFollows());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -102,9 +105,22 @@ public class IssuesService {
|
||||||
platformList.forEach(platform -> {
|
platformList.forEach(platform -> {
|
||||||
platform.updateIssue(issuesRequest);
|
platform.updateIssue(issuesRequest);
|
||||||
});
|
});
|
||||||
|
saveFollows(issuesRequest.getId(), issuesRequest.getFollows());
|
||||||
// todo 缺陷更新事件?
|
// todo 缺陷更新事件?
|
||||||
}
|
}
|
||||||
|
private void saveFollows(String issueId, List<String> follows) {
|
||||||
|
IssueFollowExample example = new IssueFollowExample();
|
||||||
|
example.createCriteria().andIssueIdEqualTo(issueId);
|
||||||
|
issueFollowMapper.deleteByExample(example);
|
||||||
|
if (!CollectionUtils.isEmpty(follows)) {
|
||||||
|
for (String follow : follows) {
|
||||||
|
IssueFollow issueFollow = new IssueFollow();
|
||||||
|
issueFollow.setIssueId(issueId);
|
||||||
|
issueFollow.setFollowId(follow);
|
||||||
|
issueFollowMapper.insert(issueFollow);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
public List<AbstractIssuePlatform> getAddPlatforms(IssuesUpdateRequest updateRequest) {
|
public List<AbstractIssuePlatform> getAddPlatforms(IssuesUpdateRequest updateRequest) {
|
||||||
List<String> platforms = new ArrayList<>();
|
List<String> platforms = new ArrayList<>();
|
||||||
if (StringUtils.isNotBlank(updateRequest.getTestCaseId())) {
|
if (StringUtils.isNotBlank(updateRequest.getTestCaseId())) {
|
||||||
|
@ -565,4 +581,15 @@ public class IssuesService {
|
||||||
return extIssuesMapper.getCountByStatus(request);
|
return extIssuesMapper.getCountByStatus(request);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<String> getFollows(String issueId) {
|
||||||
|
List<String> result = new ArrayList<>();
|
||||||
|
if (StringUtils.isBlank(issueId)) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
IssueFollowExample example = new IssueFollowExample();
|
||||||
|
example.createCriteria().andIssueIdEqualTo(issueId);
|
||||||
|
List<IssueFollow> follows = issueFollowMapper.selectByExample(example);
|
||||||
|
return follows.stream().map(IssueFollow::getFollowId).distinct().collect(Collectors.toList());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -81,7 +81,7 @@ import {buildCustomFields, parseCustomField} from "@/common/js/custom_field";
|
||||||
import CustomFiledComponent from "@/business/components/settings/workspace/template/CustomFiledComponent";
|
import CustomFiledComponent from "@/business/components/settings/workspace/template/CustomFiledComponent";
|
||||||
import TestCaseIssueList from "@/business/components/track/issue/TestCaseIssueList";
|
import TestCaseIssueList from "@/business/components/track/issue/TestCaseIssueList";
|
||||||
import IssueEditDetail from "@/business/components/track/issue/IssueEditDetail";
|
import IssueEditDetail from "@/business/components/track/issue/IssueEditDetail";
|
||||||
import {getCurrentProjectID, getCurrentUserId, getCurrentWorkspaceId} from "@/common/js/utils";
|
import {getCurrentProjectID, getCurrentUser, getCurrentUserId, getCurrentWorkspaceId} from "@/common/js/utils";
|
||||||
import {getIssueTemplate} from "@/network/custom-field-template";
|
import {getIssueTemplate} from "@/network/custom-field-template";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
@ -159,6 +159,18 @@ export default {
|
||||||
this.getThirdPartyInfo();
|
this.getThirdPartyInfo();
|
||||||
initAddFuc(data);
|
initAddFuc(data);
|
||||||
});
|
});
|
||||||
|
this.$get('/issues/follow/' + data.id, response =>{
|
||||||
|
this.form.follows = response.data;
|
||||||
|
for (let i = 0; i < response.data.length; i++) {
|
||||||
|
if(response.data[i]===this.currentUser().id){
|
||||||
|
this.showFollow = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
},
|
||||||
|
currentUser: () => {
|
||||||
|
return getCurrentUser();
|
||||||
},
|
},
|
||||||
getThirdPartyInfo() {
|
getThirdPartyInfo() {
|
||||||
let platform = this.issueTemplate.platform;
|
let platform = this.issueTemplate.platform;
|
||||||
|
@ -284,9 +296,16 @@ export default {
|
||||||
saveFollow(){
|
saveFollow(){
|
||||||
if(this.showFollow){
|
if(this.showFollow){
|
||||||
this.showFollow = false;
|
this.showFollow = false;
|
||||||
|
for (let i = 0; i < this.form.follows.length; i++) {
|
||||||
|
if(this.form.follows[i]===this.currentUser().id){
|
||||||
|
this.form.follows.splice(i,1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}else {
|
}else {
|
||||||
this.showFollow = true;
|
this.showFollow = true;
|
||||||
|
this.form.follows.push(this.currentUser().id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue