feat(用例管理): 用例评审详情新增用例评审人快捷修改

This commit is contained in:
guoyuqi 2024-04-26 10:49:41 +08:00 committed by 刘瑞斌
parent e2c4dfa03d
commit 4f5463c01a
2 changed files with 66 additions and 7 deletions

View File

@ -164,8 +164,21 @@ public class CaseReviewFunctionalCaseService {
list.forEach(item -> { list.forEach(item -> {
item.setModuleName(moduleMap.get(item.getModuleId())); item.setModuleName(moduleMap.get(item.getModuleId()));
item.setVersionName(versionMap.get(item.getVersionId())); item.setVersionName(versionMap.get(item.getVersionId()));
item.setReviewers(Collections.singletonList(userIdMap.get(item.getCaseId()))); String reviewer = userIdMap.get(item.getCaseId());
item.setReviewNames(Collections.singletonList(userNameMap.get(item.getCaseId()))); if (StringUtils.isNotBlank(reviewer)) {
item.setReviewers(new ArrayList<>(Arrays.asList(reviewer.split(","))));
}
if (StringUtils.isNotBlank(reviewer)) {
item.setReviewers(new ArrayList<>(Arrays.asList(reviewer.split(","))));
} else {
item.setReviewers(new ArrayList<>());
}
String reviewName = userNameMap.get(item.getCaseId());
if (StringUtils.isNotBlank(reviewName)) {
item.setReviewNames(new ArrayList<>(Arrays.asList(reviewName.split(","))));
} else {
item.setReviewNames(new ArrayList<>());
}
item.setCustomFields(collect.get(item.getCaseId())); item.setCustomFields(collect.get(item.getCaseId()));
if (request.isViewStatusFlag()) { if (request.isViewStatusFlag()) {
List<CaseReviewHistory> histories = caseStatusMap.get(item.getCaseId()); List<CaseReviewHistory> histories = caseStatusMap.get(item.getCaseId());

View File

@ -92,9 +92,31 @@
</TableFilter> </TableFilter>
</template> </template>
<template #reviewNames="{ record }"> <template #reviewNames="{ record }">
<a-tooltip :content="record.reviewNames.join('、')"> <MsTagGroup
<div class="one-line-text">{{ record.reviewNames.join('、') }}</div> v-if="record.showModuleTree"
</a-tooltip> :tag-list="record.reviewNames"
is-string-tag
:show-num="1"
size="small"
theme="outline"
@click="record.showModuleTree = false"
/>
<MsSelect
v-else
v-model:model-value="record.reviewers"
v-model:loading="dialogLoading"
:max-tag-count="1"
class="w-full"
:options="reviewersOptions"
:search-keys="['label']"
allow-search
size="mini"
:multiple="true"
:placeholder="t('project.messageManagement.receiverPlaceholder')"
@click.stop="record.showModuleTree = true"
@change="() => changeReviewer(record)"
>
</MsSelect>
</template> </template>
<template #status="{ record }"> <template #status="{ record }">
<div class="flex items-center gap-[4px]"> <div class="flex items-center gap-[4px]">
@ -281,6 +303,7 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { ref } from 'vue';
import { useRoute, useRouter } from 'vue-router'; import { useRoute, useRouter } from 'vue-router';
import { FormInstance, Message, SelectOptionData } from '@arco-design/web-vue'; import { FormInstance, Message, SelectOptionData } from '@arco-design/web-vue';
@ -293,6 +316,7 @@
import MsBaseTable from '@/components/pure/ms-table/base-table.vue'; import MsBaseTable from '@/components/pure/ms-table/base-table.vue';
import type { BatchActionParams, BatchActionQueryParams, MsTableColumn } from '@/components/pure/ms-table/type'; import type { BatchActionParams, BatchActionQueryParams, MsTableColumn } from '@/components/pure/ms-table/type';
import useTable from '@/components/pure/ms-table/useTable'; import useTable from '@/components/pure/ms-table/useTable';
import MsTagGroup from '@/components/pure/ms-tag/ms-tag-group.vue';
import { MsFileItem } from '@/components/pure/ms-upload/types'; import { MsFileItem } from '@/components/pure/ms-upload/types';
import caseLevel from '@/components/business/ms-case-associate/caseLevel.vue'; import caseLevel from '@/components/business/ms-case-associate/caseLevel.vue';
import MsSelect from '@/components/business/ms-select'; import MsSelect from '@/components/business/ms-select';
@ -395,6 +419,7 @@
title: 'caseManagement.caseReview.reviewer', title: 'caseManagement.caseReview.reviewer',
dataIndex: 'reviewNames', dataIndex: 'reviewNames',
slotName: 'reviewNames', slotName: 'reviewNames',
showInTable: true,
width: 150, width: 150,
}, },
{ {
@ -441,6 +466,7 @@
return { return {
...record, ...record,
caseLevel: getCaseLevels(record.customFields), caseLevel: getCaseLevels(record.customFields),
showModuleTree: true,
}; };
} }
); );
@ -634,6 +660,7 @@
...tableParams.value, ...tableParams.value,
}); });
Message.success(t('common.updateSuccess')); Message.success(t('common.updateSuccess'));
dialogLoading.value = false;
resetSelector(); resetSelector();
loadList(); loadList();
emit('refresh', tableParams.value); emit('refresh', tableParams.value);
@ -683,7 +710,7 @@
} }
// //
function changeReviewer() { function changeReviewer(record?: any) {
dialogFormRef.value?.validate(async (errors) => { dialogFormRef.value?.validate(async (errors) => {
if (!errors) { if (!errors) {
try { try {
@ -691,11 +718,12 @@
await batchChangeReviewer({ await batchChangeReviewer({
reviewId: route.query.id as string, reviewId: route.query.id as string,
userId: props.onlyMine ? userStore.id || '' : '', userId: props.onlyMine ? userStore.id || '' : '',
reviewerId: dialogForm.value.reviewer, reviewerId: dialogForm.value.reviewer.length > 0 ? dialogForm.value.reviewer : record.reviewers,
append: dialogForm.value.isAppend, // append: dialogForm.value.isAppend, //
moduleIds: props.activeFolder === 'all' ? [] : [props.activeFolder, ...props.offspringIds], moduleIds: props.activeFolder === 'all' ? [] : [props.activeFolder, ...props.offspringIds],
...batchParams.value, ...batchParams.value,
...tableParams.value, ...tableParams.value,
selectIds: batchParams.value.selectIds.length > 0 ? batchParams.value.selectIds : [record.id],
}); });
Message.success(t('common.updateSuccess')); Message.success(t('common.updateSuccess'));
dialogVisible.value = false; dialogVisible.value = false;
@ -705,6 +733,7 @@
// eslint-disable-next-line no-console // eslint-disable-next-line no-console
console.log(error); console.log(error);
} finally { } finally {
record.showModuleTree = true;
dialogLoading.value = false; dialogLoading.value = false;
} }
} }
@ -897,5 +926,22 @@
:deep(.arco-radio-label) { :deep(.arco-radio-label) {
@apply inline-flex; @apply inline-flex;
} }
:deep(.param-input:not(.arco-input-focus, .arco-select-view-focus)) {
&:not(:hover) {
border-color: transparent !important;
.arco-input::placeholder {
@apply invisible;
}
.arco-select-view-icon {
@apply invisible;
}
.arco-select-view-value {
color: var(--color-text-brand);
}
.arco-input-suffix {
@apply invisible;
}
}
}
.ms-table--special-small(); .ms-table--special-small();
</style> </style>