fix: 修复任务中心参数问题&关联用例调整

This commit is contained in:
xinxin.wu 2024-04-17 12:45:46 +08:00 committed by Craftsman
parent 9d2a050983
commit 8a8e584886
7 changed files with 69 additions and 51 deletions

View File

@ -113,7 +113,7 @@
</a-tooltip> </a-tooltip>
</template> </template>
<template #caseLevel="{ record }"> <template #caseLevel="{ record }">
<caseLevel :case-level="getCaseLevel(record)" /> <caseLevel v-if="getCaseLevel(record)" :case-level="getCaseLevel(record)" />
</template> </template>
</ms-base-table> </ms-base-table>
<div class="footer"> <div class="footer">
@ -175,7 +175,8 @@
const appStore = useAppStore(); const appStore = useAppStore();
const { t } = useI18n(); const { t } = useI18n();
const props = defineProps<{ const props = withDefaults(
defineProps<{
visible: boolean; visible: boolean;
projectId?: string; // id projectId?: string; // id
caseId?: string; // id caseId?: string; // id
@ -192,7 +193,12 @@
type: RequestModuleEnum[keyof RequestModuleEnum]; type: RequestModuleEnum[keyof RequestModuleEnum];
moduleCountParams?: TableQueryParams; // moduleCountParams?: TableQueryParams; //
hideProjectSelect?: boolean; // hideProjectSelect?: boolean; //
}>(); isHiddenCaseLevel?: boolean;
}>(),
{
isHiddenCaseLevel: false,
}
);
const emit = defineEmits<{ const emit = defineEmits<{
(e: 'update:visible', val: boolean): void; (e: 'update:visible', val: boolean): void;
@ -318,6 +324,20 @@
const keyword = ref(''); const keyword = ref('');
const version = ref(''); const version = ref('');
function getCaseLevelColumn() {
if (!props.isHiddenCaseLevel) {
return [
{
title: 'ms.case.associate.caseLevel',
dataIndex: 'caseLevel',
slotName: 'caseLevel',
width: 90,
},
];
}
return [];
}
const columns: MsTableColumn = [ const columns: MsTableColumn = [
{ {
title: 'ID', title: 'ID',
@ -342,12 +362,7 @@
showTooltip: true, showTooltip: true,
width: 250, width: 250,
}, },
{ ...getCaseLevelColumn(),
title: 'ms.case.associate.caseLevel',
dataIndex: 'caseLevel',
slotName: 'caseLevel',
width: 90,
},
{ {
title: 'ms.case.associate.tags', title: 'ms.case.associate.tags',
dataIndex: 'tags', dataIndex: 'tags',
@ -355,6 +370,10 @@
}, },
]; ];
watchEffect(() => {
getCaseLevelColumn();
});
const { propsRes, propsEvent, loadList, setLoadListParams, resetSelector, setTableSelected } = useTable( const { propsRes, propsEvent, loadList, setLoadListParams, resetSelector, setTableSelected } = useTable(
props.getTableFunc, props.getTableFunc,
{ {
@ -379,8 +398,13 @@
); );
// //
// TODO:
function getCaseLevel(record: CaseManagementTable) { function getCaseLevel(record: CaseManagementTable) {
return (record.customFields.find((item: any) => item.name === '用例等级')?.value as CaseLevel) || 'P1'; if (record.customFields && record.customFields.length) {
const caseItem = record.customFields.find((item: any) => item.fieldName === '用例等级' && item.internal);
return caseItem?.options.find((item: any) => item.value === caseItem?.defaultValue).text;
}
return undefined;
} }
const searchParams = ref<TableQueryParams>({ const searchParams = ref<TableQueryParams>({

View File

@ -78,6 +78,7 @@
:case-id="props.bugId" :case-id="props.bugId"
:associated-ids="associatedIds" :associated-ids="associatedIds"
:type="RequestModuleEnum.BUG_MANAGEMENT" :type="RequestModuleEnum.BUG_MANAGEMENT"
:is-hidden-case-level="true"
@close="emit('close')" @close="emit('close')"
@save="saveHandler" @save="saveHandler"
> >

View File

@ -64,6 +64,7 @@
:case-id="props.caseId" :case-id="props.caseId"
:associated-ids="associatedIds" :associated-ids="associatedIds"
:type="RequestModuleEnum.API_CASE" :type="RequestModuleEnum.API_CASE"
:is-hidden-case-level="true"
@close="emit('close')" @close="emit('close')"
@save="saveHandler" @save="saveHandler"
> >

View File

@ -5,7 +5,7 @@
<div class="wrapper mb-6 flex justify-between"> <div class="wrapper mb-6 flex justify-between">
<span class="font-medium text-[var(--color-text-000)]">{{ t('project.basicInfo.basicInfo') }}</span> <span class="font-medium text-[var(--color-text-000)]">{{ t('project.basicInfo.basicInfo') }}</span>
<a-button <a-button
v-if="!projectDetail?.deleted" v-show="!projectDetail?.deleted"
v-permission="['PROJECT_BASE_INFO:READ+UPDATE']" v-permission="['PROJECT_BASE_INFO:READ+UPDATE']"
type="outline" type="outline"
@click="editHandler" @click="editHandler"
@ -19,12 +19,9 @@
<span class="one-line-text mr-1 max-w-[300px] font-medium text-[var(--color-text-000)]">{{ <span class="one-line-text mr-1 max-w-[300px] font-medium text-[var(--color-text-000)]">{{
projectDetail?.name projectDetail?.name
}}</span> }}</span>
<span <span class="button mr-1" :class="[projectDetail?.deleted ? 'delete-button' : 'enable-button']">{{
v-if="!projectDetail?.deleted && projectDetail?.enable" projectDetail?.deleted ? t('project.basicInfo.deleted') : t('project.basicInfo.enable')
class="button mr-1" }}</span>
:class="[projectDetail?.enable ? 'enable-button' : 'delete-button']"
>{{ projectDetail?.enable ? t('project.basicInfo.enable') : t('project.basicInfo.enable') }}</span
>
</div> </div>
<div class="one-line-text text-xs text-[--color-text-4]">{{ projectDetail?.description }}</div> <div class="one-line-text text-xs text-[--color-text-4]">{{ projectDetail?.description }}</div>
</div> </div>

View File

@ -1,13 +1,6 @@
<template> <template>
<div class="flex flex-row items-center"> <div class="flex flex-row items-center">
<div class="text-[var(--color-text-1)]"> {{ t('project.menu.management') }}</div> <div class="text-[var(--color-text-1)]"> {{ t('project.menu.management') }}</div>
<div>
<MsIcon
class="ml-[4px] text-[var(--color-text-4)] hover:text-[rgb(var(--primary-5))]"
type="icon-icon-maybe_outlined"
/>
</div>
</div> </div>
<MsBaseTable <MsBaseTable
ref="tableRef" ref="tableRef"

View File

@ -500,7 +500,7 @@
function batchStopRealTask() { function batchStopRealTask() {
openModal({ openModal({
type: 'warning', type: 'warning',
title: t('project.taskCenter.batchStopTask', { num: batchParams.value.selectIds.length }), title: t('project.taskCenter.batchStopTask', { num: batchParams.value.currentSelectCount }),
content: t('project.taskCenter.stopTaskContent'), content: t('project.taskCenter.stopTaskContent'),
okText: t('project.taskCenter.confirmStop'), okText: t('project.taskCenter.confirmStop'),
cancelText: t('common.cancel'), cancelText: t('common.cancel'),
@ -509,11 +509,12 @@
}, },
onBeforeOk: async () => { onBeforeOk: async () => {
try { try {
const { selectIds, selectAll } = batchParams.value; const { selectIds, selectAll, excludeIds } = batchParams.value;
await loadRealMap.value[props.group].batchStop({ await loadRealMap.value[props.group].batchStop({
moduleType: props.moduleType, moduleType: props.moduleType,
selectIds: selectAll ? [] : selectIds, selectIds: selectIds || [],
selectAll, selectAll: !!selectAll,
excludeIds: excludeIds || [],
condition: { condition: {
keyword: keyword.value, keyword: keyword.value,
filter: { filter: {

View File

@ -488,7 +488,7 @@
function batchEnableTask() { function batchEnableTask() {
openModal({ openModal({
type: 'warning', type: 'warning',
title: t('project.taskCenter.batchEnableTask', { num: batchParams.value.selectIds.length }), title: t('project.taskCenter.batchEnableTask', { num: batchParams.value.currentSelectCount }),
content: t('project.taskCenter.batchEnableTaskContent'), content: t('project.taskCenter.batchEnableTaskContent'),
okText: t('project.taskCenter.confirmEnable'), okText: t('project.taskCenter.confirmEnable'),
cancelText: t('common.cancel'), cancelText: t('common.cancel'),
@ -499,8 +499,8 @@
try { try {
const { selectIds, selectAll, excludeIds } = batchParams.value; const { selectIds, selectAll, excludeIds } = batchParams.value;
await loadRealMap.value[props.group].batchEnable({ await loadRealMap.value[props.group].batchEnable({
selectIds: selectAll ? [] : selectIds, selectIds: selectIds || [],
selectAll, selectAll: !!selectAll,
scheduleTagType: props.moduleType, scheduleTagType: props.moduleType,
excludeIds, excludeIds,
condition: { condition: {
@ -526,7 +526,7 @@
function batchDisableTask() { function batchDisableTask() {
openModal({ openModal({
type: 'warning', type: 'warning',
title: t('project.taskCenter.batchDisableTask', { num: batchParams.value.selectIds.length }), title: t('project.taskCenter.batchDisableTask', { num: batchParams.value.currentSelectCount }),
content: t('project.taskCenter.batchDisableTaskContent'), content: t('project.taskCenter.batchDisableTaskContent'),
okText: t('project.taskCenter.confirmDisable'), okText: t('project.taskCenter.confirmDisable'),
cancelText: t('common.cancel'), cancelText: t('common.cancel'),
@ -535,10 +535,11 @@
}, },
onBeforeOk: async () => { onBeforeOk: async () => {
try { try {
const { selectIds, selectAll } = batchParams.value; const { selectIds, selectAll, excludeIds } = batchParams.value;
await loadRealMap.value[props.group].batchDisable({ await loadRealMap.value[props.group].batchDisable({
selectIds: selectAll ? [] : selectIds, selectIds: selectIds || [],
selectAll, selectAll: !!selectAll,
excludeIds: excludeIds || [],
scheduleTagType: props.moduleType, scheduleTagType: props.moduleType,
condition: { condition: {
keyword: keyword.value, keyword: keyword.value,