fix(用例管理): 修改用例详情bug

This commit is contained in:
xinxin.wu 2024-02-28 10:44:43 +08:00 committed by 刘瑞斌
parent 4c7a1a7690
commit 89278a4cc1
11 changed files with 192 additions and 79 deletions

View File

@ -122,8 +122,8 @@
</a-menu> </a-menu>
</div> </div>
<div class="leftContent mt-4 px-4"> <div class="leftContent mt-4 px-4">
<template v-if="activeTab === 'detail'">
<TabDetail <TabDetail
v-if="activeTab === 'detail'"
ref="tabDetailRef" ref="tabDetailRef"
:form="detailInfo" :form="detailInfo"
:allow-edit="true" :allow-edit="true"
@ -131,31 +131,14 @@
:active-tab="activeTab" :active-tab="activeTab"
@update-success="updateSuccess" @update-success="updateSuccess"
/> />
</template> <TabCaseTable v-show="activeTab === 'case'" :case-id="props.detailId" />
<template v-if="activeTab === 'requirement'"> <TabDemand v-show="activeTab === 'requirement'" :case-id="props.detailId" />
<TabDemand :active-tab="activeTab" :case-id="props.detailId" /> <TabDefect v-show="activeTab === 'bug'" :case-id="props.detailId" />
</template> <TabDependency v-show="activeTab === 'dependency'" :case-id="props.detailId" />
<template v-if="activeTab === 'case'"> <TabCaseReview v-show="activeTab === 'caseReview'" :case-id="props.detailId" />
<TabCaseTable :active-tab="activeTab" :case-id="props.detailId" /> <TabTestPlan v-show="activeTab === 'testPlan'" :active-tab="activeTab" />
</template> <TabComment v-if="activeTab === 'comments'" ref="commentRef" :case-id="props.detailId" />
<template v-if="activeTab === 'bug'"> <TabChangeHistory v-show="activeTab === 'changeHistory'" :case-id="props.detailId" />
<TabDefect :active-tab="activeTab" :case-id="props.detailId" />
</template>
<template v-if="activeTab === 'dependency'">
<TabDependency :active-tab="activeTab" :case-id="props.detailId" />
</template>
<template v-if="activeTab === 'caseReview'">
<TabCaseReview :active-tab="activeTab" :case-id="props.detailId" />
</template>
<template v-if="activeTab === 'testPlan'">
<TabTestPlan :active-tab="activeTab" />
</template>
<template v-if="activeTab === 'comments'">
<TabComment ref="commentRef" :active-tab="activeTab" :case-id="props.detailId" />
</template>
<template v-if="activeTab === 'changeHistory'">
<TabChangeHistory :active-tab="activeTab" :case-id="props.detailId" />
</template>
</div> </div>
</div> </div>
</template> </template>
@ -205,7 +188,7 @@
<span>{{ dayjs(detailInfo?.createTime).format('YYYY-MM-DD HH:mm:ss') }}</span> <span>{{ dayjs(detailInfo?.createTime).format('YYYY-MM-DD HH:mm:ss') }}</span>
</div> </div>
<div class="baseItem"> <div class="baseItem">
<span class="label"> {{ t('caseManagement.featureCase.tableColumnCreateTime') }}</span> <span class="label"> {{ t('caseManagement.featureCase.tableColumnTag') }}</span>
<span> <span>
<MsTag v-for="item of detailInfo.tags" :key="item"> {{ item }} </MsTag> <MsTag v-for="item of detailInfo.tags" :key="item"> {{ item }} </MsTag>
</span> </span>
@ -564,6 +547,7 @@
if (val) { if (val) {
showDrawerVisible.value = val; showDrawerVisible.value = val;
activeTab.value = 'detail'; activeTab.value = 'detail';
featureCaseStore.setActiveTab(activeTab.value);
} }
} }
); );
@ -625,10 +609,9 @@
} }
} }
); );
provide('activeTab', activeTab.value);
onMounted(() => { onMounted(() => {
settingDrawerRef.value.getTabModule(); // settingDrawerRef.value.getTabModule();
}); });
</script> </script>

View File

@ -48,7 +48,19 @@
<span type="text" class="px-0">{{ record.updateUserName || '-' }}</span> <span type="text" class="px-0">{{ record.updateUserName || '-' }}</span>
</template> </template>
<template #caseLevel="{ record }"> <template #caseLevel="{ record }">
<caseLevel :case-level="getCaseLevels(record.customFields)" /> <a-select
v-model:model-value="record.caseLevel"
:placeholder="t('common.pleaseSelect')"
class="param-input w-full"
@change="() => handleStatusChange(record)"
>
<template #label>
<span class="text-[var(--color-text-2)]"> <caseLevel :case-level="record.caseLevel" /></span>
</template>
<a-option v-for="item of caseLevelList" :key="item.value" :value="item.value">
<caseLevel :case-level="item.value" />
</a-option>
</a-select>
</template> </template>
<template #caseLevelFilter="{ columnConfig }"> <template #caseLevelFilter="{ columnConfig }">
<TableFilter <TableFilter
@ -815,6 +827,7 @@
}), }),
visible: false, visible: false,
showModuleTree: false, showModuleTree: false,
caseLevel: getCaseLevels(record.customFields),
}; };
}, },
updateCaseName updateCaseName
@ -1321,6 +1334,38 @@
}; };
initData(); initData();
}; };
//
async function handleStatusChange(record: any) {
try {
const detailResult = await getCaseDetail(record.id);
const { customFields } = detailResult;
const customFieldsList = customFields.map((item: any) => {
if (item.internal && item.fieldName === '用例等级') {
return {
fieldId: item.fieldId,
value: record.caseLevel,
};
}
return {
fieldId: item.fieldId,
value: Array.isArray(item.defaultValue) ? JSON.stringify(item.defaultValue) : item.defaultValue,
};
});
const params = {
request: {
...detailResult,
customFields: customFieldsList,
},
fileList: [],
};
await updateCaseRequest(params);
initData();
Message.success(t('common.updateSuccess'));
} catch (error) {
// eslint-disable-next-line no-console
console.log(error);
}
}
// //
async function changeHandler(data: TableData[], extra: TableChangeExtra, currentData: TableData[]) { async function changeHandler(data: TableData[], extra: TableChangeExtra, currentData: TableData[]) {
@ -1475,4 +1520,18 @@
color: var(--color-text-2); color: var(--color-text-2);
} }
} }
: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);
}
}
}
</style> </style>

View File

@ -128,9 +128,8 @@
const props = defineProps<{ const props = defineProps<{
caseId: string; caseId: string;
activeTab: string;
}>(); }>();
const activeTab = computed(() => featureCaseStore.activeTab);
const showType = ref('link'); const showType = ref('link');
const keyword = ref<string>(''); const keyword = ref<string>('');
@ -323,9 +322,18 @@
} }
); );
onMounted(() => { watch(
() => activeTab.value,
(val) => {
if (val === 'bug') {
getFetch(); getFetch();
}); }
}
);
// onMounted(() => {
// getFetch();
// });
</script> </script>
<style scoped></style> <style scoped></style>

View File

@ -97,11 +97,6 @@
const { t } = useI18n(); const { t } = useI18n();
const currentProjectId = computed(() => appStore.currentProjectId); const currentProjectId = computed(() => appStore.currentProjectId);
const activeTab = inject<string>('activeTab');
const newActive = computed(() => {
return activeTab;
});
console.log(newActive.value);
const props = defineProps<{ const props = defineProps<{
caseId: string; // id caseId: string; // id
}>(); }>();
@ -276,11 +271,22 @@
setKeyword(keyword.value); setKeyword(keyword.value);
await loadList(); await loadList();
} }
const activeTab = computed(() => featureCaseStore.activeTab);
onMounted(async () => { watch(
() => activeTab.value,
(val) => {
if (val === 'case') {
getEnabledModules(); getEnabledModules();
getFetch(); getFetch();
}); }
}
);
// onMounted(async () => {
// getEnabledModules();
// getFetch();
// });
</script> </script>
<style scoped></style> <style scoped></style>

View File

@ -48,11 +48,11 @@
import debounce from 'lodash-es/debounce'; import debounce from 'lodash-es/debounce';
const featureCaseStore = useFeatureCaseStore(); const featureCaseStore = useFeatureCaseStore();
const activeTab = computed(() => featureCaseStore.activeTab);
const { t } = useI18n(); const { t } = useI18n();
const props = defineProps<{ const props = defineProps<{
caseId: string; // id caseId: string; // id
activeTab: string;
}>(); }>();
const keyword = ref<string>(''); const keyword = ref<string>('');
@ -114,9 +114,18 @@
initData(); initData();
}, 100); }, 100);
onMounted(() => { watch(
() => activeTab.value,
(val) => {
if (val === 'caseReview') {
initData(); initData();
}); }
}
);
// onMounted(() => {
// initData();
// });
</script> </script>
<style scoped></style> <style scoped></style>

View File

@ -95,13 +95,13 @@
const appStore = useAppStore(); const appStore = useAppStore();
const featureCaseStore = useFeatureCaseStore(); const featureCaseStore = useFeatureCaseStore();
const activeTab = computed(() => featureCaseStore.activeTab);
const visitedKey = 'notRemindChangeHistoryTip'; const visitedKey = 'notRemindChangeHistoryTip';
const { addVisited } = useVisit(visitedKey); const { addVisited } = useVisit(visitedKey);
const { getIsVisited } = useVisit(visitedKey); const { getIsVisited } = useVisit(visitedKey);
const props = defineProps<{ const props = defineProps<{
caseId: string; caseId: string;
activeTab: string;
}>(); }>();
const columns: MsTableColumn = [ const columns: MsTableColumn = [
@ -247,10 +247,20 @@
featureCaseStore.getCaseCounts(props.caseId); featureCaseStore.getCaseCounts(props.caseId);
} }
onMounted(() => { watch(
() => activeTab.value,
(val) => {
if (val === 'changeHistory') {
doCheckIsTip(); doCheckIsTip();
initData(); initData();
}); }
}
);
// onMounted(() => {
// doCheckIsTip();
// initData();
// });
</script> </script>
<style scoped></style> <style scoped></style>

View File

@ -33,7 +33,7 @@
import { ref } from 'vue'; import { ref } from 'vue';
import { Message } from '@arco-design/web-vue'; import { Message } from '@arco-design/web-vue';
import MsComment from '@/components/business/ms-comment/comment'; import MsComment from '@/components/business/ms-comment';
import { CommentItem, CommentParams } from '@/components/business/ms-comment/types'; import { CommentItem, CommentParams } from '@/components/business/ms-comment/types';
import { import {
@ -47,12 +47,12 @@
import useFeatureCaseStore from '@/store/modules/case/featureCase'; import useFeatureCaseStore from '@/store/modules/case/featureCase';
const featureCaseStore = useFeatureCaseStore(); const featureCaseStore = useFeatureCaseStore();
const activeTab = computed(() => featureCaseStore.activeTab);
const { openModal } = useModal(); const { openModal } = useModal();
const { t } = useI18n(); const { t } = useI18n();
const props = defineProps<{ const props = defineProps<{
caseId: string; caseId: string;
activeTab: string;
}>(); }>();
const activeComment = ref('caseComment'); const activeComment = ref('caseComment');
@ -104,6 +104,7 @@
// //
async function handleUpdateOrAdd(item: CommentParams, cb: (result: boolean) => void) { async function handleUpdateOrAdd(item: CommentParams, cb: (result: boolean) => void) {
debugger;
try { try {
if (item.id) { if (item.id) {
await updateCommentList(item); await updateCommentList(item);
@ -151,6 +152,14 @@
} }
} }
); );
// watch(
// () => activeTab.value,
// (val) => {
// if (val === 'comments') {
// getAllCommentList();
// }
// }
// );
onMounted(() => { onMounted(() => {
getAllCommentList(); getAllCommentList();

View File

@ -99,17 +99,17 @@
import { getCaseRelatedInfo } from '@/api/modules/project-management/menuManagement'; import { getCaseRelatedInfo } from '@/api/modules/project-management/menuManagement';
import { useI18n } from '@/hooks/useI18n'; import { useI18n } from '@/hooks/useI18n';
import { useAppStore } from '@/store'; import { useAppStore } from '@/store';
import useFeatureCaseStore from '@/store/modules/case/featureCase';
import type { CreateOrUpdateDemand, DemandItem } from '@/models/caseManagement/featureCase'; import type { CreateOrUpdateDemand, DemandItem } from '@/models/caseManagement/featureCase';
import { TableKeyEnum } from '@/enums/tableEnum'; import { TableKeyEnum } from '@/enums/tableEnum';
const { t } = useI18n(); const { t } = useI18n();
const appStore = useAppStore(); const appStore = useAppStore();
const featureCaseStore = useFeatureCaseStore();
const currentProjectId = computed(() => appStore.currentProjectId); const currentProjectId = computed(() => appStore.currentProjectId);
const props = defineProps<{ const props = defineProps<{
caseId: string; caseId: string;
activeTab: string;
}>(); }>();
const keyword = ref<string>(''); const keyword = ref<string>('');
@ -354,8 +354,22 @@
showAddModel.value = true; showAddModel.value = true;
modelForm.value = { ...initModelForm }; modelForm.value = { ...initModelForm };
} }
const activeTab = computed(() => featureCaseStore.activeTab);
// onMounted(async () => {
// try {
// const result = await getCaseRelatedInfo(currentProjectId.value);
// if (result && result.platform_key) {
// platformInfo.value = { ...result };
// }
// } catch (error) {
// console.log(error);
// }
// });
onMounted(async () => { watch(
() => activeTab.value,
async (val) => {
if (val === 'requirement') {
try { try {
const result = await getCaseRelatedInfo(currentProjectId.value); const result = await getCaseRelatedInfo(currentProjectId.value);
if (result && result.platform_key) { if (result && result.platform_key) {
@ -364,7 +378,9 @@
} catch (error) { } catch (error) {
console.log(error); console.log(error);
} }
}); }
}
);
function getPlatName() { function getPlatName() {
switch (platformInfo.value.platform_key) { switch (platformInfo.value.platform_key) {

View File

@ -84,6 +84,7 @@
import { characterLimit } from '@/utils'; import { characterLimit } from '@/utils';
const featureCaseStore = useFeatureCaseStore(); const featureCaseStore = useFeatureCaseStore();
const activeTab = computed(() => featureCaseStore.activeTab);
const appStore = useAppStore(); const appStore = useAppStore();
@ -94,7 +95,6 @@
const keyword = ref<string>(''); const keyword = ref<string>('');
const props = defineProps<{ const props = defineProps<{
caseId: string; caseId: string;
activeTab: string;
}>(); }>();
const columns: MsTableColumn = [ const columns: MsTableColumn = [
@ -216,9 +216,18 @@
} }
); );
onMounted(() => { watch(
() => activeTab.value,
(val) => {
if (val === 'dependency') {
initData(); initData();
}); }
}
);
// onMounted(() => {
// initData();
// });
</script> </script>
<style scoped></style> <style scoped></style>

View File

@ -284,6 +284,7 @@
import { getModules, getModulesCount } from '@/api/modules/project-management/fileManagement'; import { getModules, getModulesCount } from '@/api/modules/project-management/fileManagement';
import { useI18n } from '@/hooks/useI18n'; import { useI18n } from '@/hooks/useI18n';
import useAppStore from '@/store/modules/app'; import useAppStore from '@/store/modules/app';
import useFeatureCaseStore from '@/store/modules/case/featureCase';
import { downloadByteFile, getGenerateId } from '@/utils'; import { downloadByteFile, getGenerateId } from '@/utils';
import { scrollIntoView } from '@/utils/dom'; import { scrollIntoView } from '@/utils/dom';
@ -296,7 +297,7 @@
const appStore = useAppStore(); const appStore = useAppStore();
const currentProjectId = computed(() => appStore.currentProjectId); const currentProjectId = computed(() => appStore.currentProjectId);
const featureCaseStore = useFeatureCaseStore();
const { t } = useI18n(); const { t } = useI18n();
const props = withDefaults( const props = withDefaults(
@ -304,7 +305,7 @@
form: DetailCase; form: DetailCase;
allowEdit?: boolean; // allowEdit?: boolean; //
formRules?: FormRuleItem[]; // formRules?: FormRuleItem[]; //
activeTab?: string; activeTab?: string | number;
}>(), }>(),
{ {
allowEdit: true, // allowEdit: true, //

View File

@ -30,9 +30,12 @@
import { getRecycleListRequest } from '@/api/modules/case-management/featureCase'; import { getRecycleListRequest } from '@/api/modules/case-management/featureCase';
import { useI18n } from '@/hooks/useI18n'; import { useI18n } from '@/hooks/useI18n';
import useFeatureCaseStore from '@/store/modules/case/featureCase';
import { TableKeyEnum } from '@/enums/tableEnum'; import { TableKeyEnum } from '@/enums/tableEnum';
const featureCaseStore = useFeatureCaseStore();
const activeTab = computed(() => featureCaseStore.activeTab);
const { t } = useI18n(); const { t } = useI18n();
const keyword = ref<string>(''); const keyword = ref<string>('');