fix(工作台): 修复工作台系统卡片人员bug
This commit is contained in:
parent
c0d70a8d0a
commit
18cdf76a95
|
@ -29,8 +29,7 @@
|
||||||
:prefix="t('workbench.homePage.staff')"
|
:prefix="t('workbench.homePage.staff')"
|
||||||
:multiple="true"
|
:multiple="true"
|
||||||
:has-all-select="true"
|
:has-all-select="true"
|
||||||
:default-all-select="innerHandleUsers.length === 0"
|
@popup-visible-change="popupVisibleChange"
|
||||||
@change="changeMember"
|
|
||||||
>
|
>
|
||||||
</MsSelect>
|
</MsSelect>
|
||||||
</div>
|
</div>
|
||||||
|
@ -60,7 +59,6 @@
|
||||||
import type { OverViewOfProject, SelectedCardItem, TimeFormParams } from '@/models/workbench/homePage';
|
import type { OverViewOfProject, SelectedCardItem, TimeFormParams } from '@/models/workbench/homePage';
|
||||||
|
|
||||||
import { getColorScheme, getCommonBarOptions, handleNoDataDisplay } from '../utils';
|
import { getColorScheme, getCommonBarOptions, handleNoDataDisplay } from '../utils';
|
||||||
import type { SelectOptionData } from '@arco-design/web-vue';
|
|
||||||
|
|
||||||
const { t } = useI18n();
|
const { t } = useI18n();
|
||||||
const appStore = useAppStore();
|
const appStore = useAppStore();
|
||||||
|
@ -92,7 +90,7 @@
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
|
|
||||||
const memberOptions = ref<SelectOptionData[]>([]);
|
const memberOptions = ref<{ label: string; value: string }[]>([]);
|
||||||
|
|
||||||
const options = ref<Record<string, any>>({});
|
const options = ref<Record<string, any>>({});
|
||||||
|
|
||||||
|
@ -178,24 +176,30 @@
|
||||||
label: e.text,
|
label: e.text,
|
||||||
value: e.value,
|
value: e.value,
|
||||||
}));
|
}));
|
||||||
innerHandleUsers.value = innerHandleUsers.value.filter((id: string) =>
|
innerHandleUsers.value = memberOptions.value.map((e) => e.value);
|
||||||
memberOptions.value.some((member) => member.value === id)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeProject() {
|
async function handleProjectChange(isRefreshKey: boolean = false) {
|
||||||
innerHandleUsers.value = [];
|
await nextTick();
|
||||||
nextTick(() => {
|
if (!isRefreshKey) {
|
||||||
|
await getMemberOptions();
|
||||||
|
}
|
||||||
|
await getDefectMemberDetail();
|
||||||
|
}
|
||||||
|
|
||||||
|
async function changeProject() {
|
||||||
|
await handleProjectChange(false);
|
||||||
emit('change');
|
emit('change');
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeMember() {
|
function popupVisibleChange(val: boolean) {
|
||||||
|
if (!val) {
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
getDefectMemberDetail();
|
getDefectMemberDetail();
|
||||||
emit('change');
|
emit('change');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
() => props.item.projectIds,
|
() => props.item.projectIds,
|
||||||
|
@ -230,15 +234,12 @@
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
watch([() => props.refreshKey, () => projectId.value], async () => {
|
watch([() => props.refreshKey, () => projectId.value], ([refreshKey]) => {
|
||||||
await nextTick();
|
handleProjectChange(!!refreshKey);
|
||||||
getMemberOptions();
|
|
||||||
getDefectMemberDetail();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
getMemberOptions();
|
handleProjectChange(false);
|
||||||
getDefectMemberDetail();
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="card-wrapper">
|
<div class="card-wrapper">
|
||||||
<CardSkeleton v-if="showSkeleton" :show-skeleton="showSkeleton" />
|
<CardSkeleton v-if="showSkeleton" :show-skeleton="showSkeleton" />
|
||||||
<div v-show="!showSkeleton">
|
<div v-else>
|
||||||
<div class="flex items-center justify-between">
|
<div class="flex items-center justify-between">
|
||||||
<a-tooltip :content="t(props.item.label)" position="tl">
|
<a-tooltip :content="t(props.item.label)" position="tl">
|
||||||
<div class="title one-line-text"> {{ t(props.item.label) }} </div>
|
<div class="title one-line-text"> {{ t(props.item.label) }} </div>
|
||||||
|
@ -21,7 +21,7 @@
|
||||||
:has-all-select="true"
|
:has-all-select="true"
|
||||||
:default-all-select="props.item.selectAll"
|
:default-all-select="props.item.selectAll"
|
||||||
:at-least-one="true"
|
:at-least-one="true"
|
||||||
@change="changeProject"
|
@popup-visible-change="popupVisibleChange"
|
||||||
>
|
>
|
||||||
</MsSelect>
|
</MsSelect>
|
||||||
</div>
|
</div>
|
||||||
|
@ -152,7 +152,7 @@
|
||||||
projectIds: innerProjectIds.value,
|
projectIds: innerProjectIds.value,
|
||||||
organizationId: appStore.currentOrgId,
|
organizationId: appStore.currentOrgId,
|
||||||
handleUsers: [],
|
handleUsers: [],
|
||||||
selectAll: selectAll.value,
|
selectAll: innerSelectAll.value,
|
||||||
};
|
};
|
||||||
let detail;
|
let detail;
|
||||||
if (props.item.key === WorkCardEnum.PROJECT_VIEW) {
|
if (props.item.key === WorkCardEnum.PROJECT_VIEW) {
|
||||||
|
@ -170,17 +170,33 @@
|
||||||
showSkeleton.value = false;
|
showSkeleton.value = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const isInit = ref(true);
|
|
||||||
function changeProject() {
|
function handleProjectChange(shouldEmit = false) {
|
||||||
if (isInit.value) return;
|
// 项目切换逻辑
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
innerSelectAll.value = selectAll.value;
|
innerSelectAll.value = selectAll.value;
|
||||||
emit('change');
|
initOverViewDetail();
|
||||||
|
if (shouldEmit) emit('change');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function popupVisibleChange(val: boolean) {
|
||||||
|
if (!val) {
|
||||||
|
handleProjectChange(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function handleRefreshKeyChange() {
|
||||||
|
await nextTick(() => {
|
||||||
|
innerProjectIds.value = [...props.item.projectIds];
|
||||||
|
innerSelectAll.value = props.item.selectAll;
|
||||||
|
});
|
||||||
|
setTimeout(() => {
|
||||||
|
initOverViewDetail();
|
||||||
|
}, 0);
|
||||||
|
}
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
isInit.value = false;
|
|
||||||
initOverViewDetail();
|
initOverViewDetail();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -191,15 +207,10 @@
|
||||||
initOverViewDetail();
|
initOverViewDetail();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{ deep: true }
|
||||||
deep: true,
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
|
|
||||||
watch([() => props.refreshKey, () => innerProjectIds.value], async () => {
|
watch(() => props.refreshKey, handleRefreshKeyChange);
|
||||||
await nextTick();
|
|
||||||
initOverViewDetail();
|
|
||||||
});
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="less">
|
<style scoped lang="less">
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
:search-keys="['name']"
|
:search-keys="['name']"
|
||||||
class="!w-[200px]"
|
class="!w-[200px]"
|
||||||
:prefix="t('workbench.homePage.project')"
|
:prefix="t('workbench.homePage.project')"
|
||||||
|
@change="changeProject"
|
||||||
>
|
>
|
||||||
</MsSelect>
|
</MsSelect>
|
||||||
|
|
||||||
|
@ -24,6 +25,7 @@
|
||||||
:options="memberOptions"
|
:options="memberOptions"
|
||||||
allow-search
|
allow-search
|
||||||
allow-clear
|
allow-clear
|
||||||
|
:placeholder="t('ms.case.associate.allData')"
|
||||||
value-key="value"
|
value-key="value"
|
||||||
label-key="label"
|
label-key="label"
|
||||||
:search-keys="['label']"
|
:search-keys="['label']"
|
||||||
|
@ -31,8 +33,7 @@
|
||||||
:prefix="t('workbench.homePage.staff')"
|
:prefix="t('workbench.homePage.staff')"
|
||||||
:multiple="true"
|
:multiple="true"
|
||||||
:has-all-select="true"
|
:has-all-select="true"
|
||||||
:default-all-select="innerHandleUsers.length === 0"
|
@popup-visible-change="popupVisibleChange"
|
||||||
@change="changeMember"
|
|
||||||
>
|
>
|
||||||
</MsSelect>
|
</MsSelect>
|
||||||
</div>
|
</div>
|
||||||
|
@ -58,7 +59,7 @@
|
||||||
import { workMemberViewDetail, workProjectMemberOptions } from '@/api/modules/workbench';
|
import { workMemberViewDetail, workProjectMemberOptions } from '@/api/modules/workbench';
|
||||||
import { useI18n } from '@/hooks/useI18n';
|
import { useI18n } from '@/hooks/useI18n';
|
||||||
import useAppStore from '@/store/modules/app';
|
import useAppStore from '@/store/modules/app';
|
||||||
import { characterLimit, sleep } from '@/utils';
|
import { characterLimit } from '@/utils';
|
||||||
|
|
||||||
import type { OverViewOfProject, SelectedCardItem, TimeFormParams } from '@/models/workbench/homePage';
|
import type { OverViewOfProject, SelectedCardItem, TimeFormParams } from '@/models/workbench/homePage';
|
||||||
|
|
||||||
|
@ -145,19 +146,30 @@
|
||||||
label: e.name,
|
label: e.name,
|
||||||
value: e.id,
|
value: e.id,
|
||||||
}));
|
}));
|
||||||
innerHandleUsers.value = innerHandleUsers.value.filter((id: string) =>
|
innerHandleUsers.value = memberOptions.value.map((e) => e.value);
|
||||||
memberOptions.value.some((member) => member.value === id)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
const isInit = ref(true);
|
|
||||||
|
|
||||||
function changeMember(value: string[]) {
|
async function handleProjectChange(isRefreshKey: boolean = false) {
|
||||||
|
await nextTick();
|
||||||
|
if (!isRefreshKey) {
|
||||||
|
await getMemberOptions();
|
||||||
|
}
|
||||||
|
await initOverViewMemberDetail();
|
||||||
|
}
|
||||||
|
|
||||||
|
async function changeProject() {
|
||||||
|
await handleProjectChange(false);
|
||||||
|
emit('change');
|
||||||
|
}
|
||||||
|
|
||||||
|
function popupVisibleChange(val: boolean) {
|
||||||
|
if (!val) {
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
initOverViewMemberDetail();
|
initOverViewMemberDetail();
|
||||||
innerHandleUsers.value = value;
|
|
||||||
emit('change');
|
emit('change');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
watch(
|
watch(
|
||||||
() => props.item.projectIds,
|
() => props.item.projectIds,
|
||||||
|
@ -192,28 +204,12 @@
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
onMounted(() => {
|
watch([() => props.refreshKey, () => projectId.value], ([refreshKey]) => {
|
||||||
isInit.value = false;
|
handleProjectChange(!!refreshKey);
|
||||||
if (props.item.projectIds.length) {
|
|
||||||
getMemberOptions();
|
|
||||||
}
|
|
||||||
initOverViewMemberDetail();
|
|
||||||
});
|
});
|
||||||
|
|
||||||
watch([() => props.refreshKey, () => projectId.value], async ([_key, newProjectId]) => {
|
onMounted(() => {
|
||||||
await nextTick();
|
handleProjectChange(false);
|
||||||
|
|
||||||
if (newProjectId) {
|
|
||||||
innerHandleUsers.value = [];
|
|
||||||
emit('change');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (props.item.projectIds.length) {
|
|
||||||
getMemberOptions();
|
|
||||||
}
|
|
||||||
await sleep(50);
|
|
||||||
|
|
||||||
initOverViewMemberDetail();
|
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -317,7 +317,7 @@
|
||||||
|
|
||||||
// 刷新
|
// 刷新
|
||||||
async function handleRefresh() {
|
async function handleRefresh() {
|
||||||
initDefaultList();
|
await initDefaultList();
|
||||||
refreshKey.value = Date.now();
|
refreshKey.value = Date.now();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue