This commit is contained in:
xingyu4j
2025-09-25 11:23:52 +08:00
3 changed files with 11 additions and 13 deletions

View File

@@ -1,5 +1,7 @@
import { defineAsyncComponent } from 'vue'; import { defineAsyncComponent } from 'vue';
// TODO @xingyu我直接引入貌似没问题呀。
// TODO @xingyuapps/web-antd/src/views/crm/followup/index.ts 走的异步组件,不过名字是 FollowUp 没 Async。可能要一起讨论怎么保持相对的一致性
export const AsyncOperateLog = defineAsyncComponent( export const AsyncOperateLog = defineAsyncComponent(
() => import('./operate-log.vue'), () => import('./operate-log.vue'),
); );

View File

@@ -2,7 +2,7 @@
import type { CrmClueApi } from '#/api/crm/clue'; import type { CrmClueApi } from '#/api/crm/clue';
import type { SystemOperateLogApi } from '#/api/system/operate-log'; import type { SystemOperateLogApi } from '#/api/system/operate-log';
import { computed, defineAsyncComponent, onMounted, ref } from 'vue'; import { computed, onMounted, ref } from 'vue';
import { useRoute, useRouter } from 'vue-router'; import { useRoute, useRouter } from 'vue-router';
import { confirm, Page, useVbenModal } from '@vben/common-ui'; import { confirm, Page, useVbenModal } from '@vben/common-ui';
@@ -15,22 +15,19 @@ import { getClue, transformClue } from '#/api/crm/clue';
import { getOperateLogPage } from '#/api/crm/operateLog'; import { getOperateLogPage } from '#/api/crm/operateLog';
import { BizTypeEnum } from '#/api/crm/permission'; import { BizTypeEnum } from '#/api/crm/permission';
import { useDescription } from '#/components/description'; import { useDescription } from '#/components/description';
// TODO @芋艿:要不要 AsyncOperateLog 风格? import { OperateLog } from '#/components/operate-log';
import { AsyncOperateLog } from '#/components/operate-log';
import { FollowUp } from '#/views/crm/followup'; import { FollowUp } from '#/views/crm/followup';
import { PermissionList, TransferForm } from '#/views/crm/permission'; import { PermissionList, TransferForm } from '#/views/crm/permission';
import ClueForm from '../modules/form.vue'; import Form from '../modules/form.vue';
import { useDetailSchema } from './data'; import { useDetailSchema } from './data';
import Info from './modules/info.vue';
const ClueInfo = defineAsyncComponent(() => import('./modules/info.vue'));
const loading = ref(false);
const route = useRoute(); const route = useRoute();
const router = useRouter(); const router = useRouter();
const tabs = useTabs(); const tabs = useTabs();
const loading = ref(false); // 加载中
const clueId = ref(0); // 线索编号 const clueId = ref(0); // 线索编号
const clue = ref<CrmClueApi.Clue>({} as CrmClueApi.Clue); // 线索详情 const clue = ref<CrmClueApi.Clue>({} as CrmClueApi.Clue); // 线索详情
const logList = ref<SystemOperateLogApi.OperateLog[]>([]); // 操作日志 const logList = ref<SystemOperateLogApi.OperateLog[]>([]); // 操作日志
@@ -52,7 +49,7 @@ const [Descriptions] = useDescription({
}); });
const [FormModal, formModalApi] = useVbenModal({ const [FormModal, formModalApi] = useVbenModal({
connectedComponent: ClueForm, connectedComponent: Form,
destroyOnClose: true, destroyOnClose: true,
}); });
@@ -155,12 +152,12 @@ onMounted(() => {
<Descriptions :data="clue" /> <Descriptions :data="clue" />
</Card> </Card>
<Card class="mt-4 min-h-[60%]"> <Card class="mt-4 min-h-[60%]">
<Tabs class="tabs-tight" :tab-bar-gutter="16"> <Tabs :tab-bar-gutter="16">
<Tabs.TabPane tab="跟进记录" key="1" :force-render="true"> <Tabs.TabPane tab="跟进记录" key="1" :force-render="true">
<FollowUp :biz-id="clueId" :biz-type="BizTypeEnum.CRM_CLUE" /> <FollowUp :biz-id="clueId" :biz-type="BizTypeEnum.CRM_CLUE" />
</Tabs.TabPane> </Tabs.TabPane>
<Tabs.TabPane tab="基本信息" key="2" :force-render="true"> <Tabs.TabPane tab="基本信息" key="2" :force-render="true">
<ClueInfo :clue="clue" /> <Info :clue="clue" />
</Tabs.TabPane> </Tabs.TabPane>
<Tabs.TabPane tab="团队成员" key="3" :force-render="true"> <Tabs.TabPane tab="团队成员" key="3" :force-render="true">
<PermissionList <PermissionList
@@ -172,7 +169,7 @@ onMounted(() => {
/> />
</Tabs.TabPane> </Tabs.TabPane>
<Tabs.TabPane tab="操作日志" key="4" :force-render="true"> <Tabs.TabPane tab="操作日志" key="4" :force-render="true">
<AsyncOperateLog :log-list="logList" /> <OperateLog :log-list="logList" />
</Tabs.TabPane> </Tabs.TabPane>
</Tabs> </Tabs>
</Card> </Card>

View File

@@ -34,7 +34,6 @@ const [SystemDescriptions] = useDescription({
</script> </script>
<template> <template>
<!-- TODO @芋艿为什么 p-4 -->
<div class="p-4"> <div class="p-4">
<BaseDescriptions :data="clue" /> <BaseDescriptions :data="clue" />
<Divider /> <Divider />