123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652 |
- <template>
- <div class="home">
- <!--网站概况-->
- <a-row class="top-title">
- <a-col :span="24">
- <div style="display: flex; margin-top: 20px">
- <span class="t1"> 站点: </span>
- <select-site @set-site-info="changeUser" selectWidth="300px" />
- <a :href="siteDomain" class="web-link" target="_blank">{{ siteDomain }}</a>
- </div>
- </a-col>
- </a-row>
- <!--基础信息-->
- <a-card title="网站概况">
- <a-row >
- <a-col class="border-right" :span="12" >
- <a-spin :spinning="baseInfoLoading">
- <a-row class="web-info">
- <a-col :span="8">
- <div class="web-content">
- <p class="title">交付状态</p>
- <p class="content">
- <span>{{ filter_Null_format(baseInfo.deliveryProgress) }}</span>
- </p>
- <a-progress style="width: 40%" :steps="6" :percent="baseInfo.percentage" />
- </div>
- </a-col>
- <a-col :span="8">
- <div class="web-content">
- <p class="title">运行状态</p>
- <p class="content">
- <span v-if="baseInfo.runStatus == 0">创建失败</span><span v-if="baseInfo.runStatus == 1">正常运行</span
- ><span v-if="baseInfo.runStatus == 2">运行异常</span>
- <span v-if="baseInfo.runStatus == 3">站点停止</span>
- </p>
- </div>
- </a-col>
- <a-col :span="8">
- <div class="web-content">
- <p class="title">网站运行</p>
- <p class="content">
- <span>
- {{ filter_Null_format(baseInfo.runDays) }}天
- </span>
- </p>
- </div>
- </a-col>
- </a-row>
- </a-spin>
- </a-col>
- <a-col :span="12">
- <a-spin :spinning="baseInfoLoading">
- <a-row class="web-info">
- <a-col :span="8">
- <div class="web-content">
- <p class="title">套餐类型</p>
- <p class="content">
- <span>{{ filter_Null_format(baseInfo.planName) }}</span>
- </p>
- </div>
- </a-col>
- <a-col :span="8">
- <div class="web-content">
- <p class="title">提单时间</p>
- <p class="content">
- <span>{{ filter_Null_format(baseInfo.createTime) }}</span>
- </p>
- </div>
- </a-col>
- <a-col :span="8">
- <div class="web-content">
- <p class="title">预计服务到期时间</p>
- <p class="content">
- <span >{{ filter_Null_format(baseInfo.endTime) }}</span>
- </p>
- </div>
- </a-col>
- </a-row>
- </a-spin>
- </a-col>
- </a-row>
- </a-card>
- <a-row class="r3">
- <a-col :span="24">
- <a-card title="核心数据">
- <a-row class="r5" :gutter="[20, 20]">
- <a-col :span="4" class="border-right">
- <div class="wrap effect">
- <a-spin :spinning="coreInfoLoading">
- <!-- <router-link :to="{ path: '/inquiry/list', query: { timeType: 'thisWeek' } }">-->
- <div class="fr">
- <p class="title">本周询盘数</p>
- <p class="theme-color">{{ filter_Null_format(currentWeekEnquiryCount) }}</p>
- </div>
- <!-- </router-link>-->
- </a-spin>
- </div>
- </a-col>
- <a-col :span="4" class="border-right">
- <div class="wrap effect">
- <a-spin :spinning="coreInfoLoading">
- <!-- <router-link :to="{ path: '/inquiry/list', query: { timeType: 'thisMonth' } }">-->
- <div class="fr">
- <p class="title">本月询盘数</p>
- <p class="theme-color">{{ filter_Null_format(currentMonthEnquiryCount) }}</p>
- </div>
- <!-- </router-link>-->
- </a-spin>
- </div>
- </a-col>
- <a-col :span="4" class="border-right">
- <!-- <router-link :to="{ path: '/inquiry/list' }">-->
- <div class="wrap effect">
- <a-spin :spinning="coreInfoLoading">
- <div class="fr">
- <p class="title">累计询盘数</p>
- <p class="theme-color">{{ filter_Null_format(totalEnquiryCount) }}</p>
- </div>
- </a-spin>
- </div>
- <!-- </router-link>-->
- </a-col>
- <a-col :span="4" class="border-right">
- <div class="wrap blue">
- <a-spin :spinning="coreInfoLoading">
- <div class="fr">
- <p class="title">本周流量</p>
- <p>{{ filter_Null_format(thisWeekData.totalUsers) }}</p>
- </div>
- </a-spin>
- </div>
- </a-col>
- <a-col :span="4" class="border-right">
- <div class="wrap blue">
- <a-spin :spinning="coreInfoLoading">
- <div class="fr">
- <p class="title">本月流量</p>
- <p>{{ filter_Null_format(thisMonthData.totalUsers) }}</p>
- </div>
- </a-spin>
- </div>
- </a-col>
- <a-col :span="4">
- <div class="wrap blue">
- <a-spin :spinning="coreInfoLoading">
- <div class="fr">
- <p class="title">累计流量</p>
- <p>{{ filter_Null_format(allTimeData.totalUsers) }}</p>
- </div>
- </a-spin>
- </div>
- </a-col>
- <a-col :span="24" style="margin-top: 10px">
- <a-table
- class="ant-table-striped"
- :loading="coreDetailLoading"
- :columns="columns"
- :pagination="false"
- :data-source="coreDataTable"
- :row-class-name="(_record, index) => (index % 2 === 1 ? 'table-striped' : null)"
- bordered
- >
- </a-table>
- <p style="color: #999; font-size: 13px">注:今日数据每小时更新一次。</p>
- </a-col>
- <a-row class="r5-1">
- <div class="fl">
- <a-button :type="timeChooseIndex == 7 ? 'primary' : ''" @click="changeTime(7)"> 最近7天 </a-button>
- <a-button :type="timeChooseIndex == 30 ? 'primary' : ''" @click="changeTime(30)"> 最近30天 </a-button>
- <a-button :type="timeChooseIndex == 180 ? 'primary' : ''" @click="changeTime(180)"> 最近六个月 </a-button>
- </div>
- <a-col :span="24">
- <div class="fr" v-if="coreDataChart.x.length > 0">
- <span><i style="background: #53A2D3"></i>访客数(UV)</span>
- <span><i style="background: #FF951A"></i>浏览量(PV)</span>
- <span><i style="background: #399C5C"></i>询盘数</span>
- </div>
- <a-spin :spinning="chartsLoading" style="float: left; width: 100%">
- <area-chart v-if="coreDataChart.x.length > 0" :dataSource="coreDataChart" />
- <a-empty v-else style="float: right; width: 100%; margin-top: 110px" />
- </a-spin>
- </a-col>
- </a-row>
- <a-row class="r5-1" :gutter="[20, 20]">
- <a-col style="width: 20%" class="border-right">
- <div class="wrap">
- <div class="fr">
- <p class="title">日均访问量</p>
- <p style="font-size: 25px">{{ averageVisit }}</p>
- </div>
- </div>
- </a-col>
- <a-col style="width: 20%" class="border-right">
- <div class="wrap">
- <div class="fr">
- <p class="title">平均访问时长</p>
- <p style="font-size: 25px">{{ averageVisitDuration }}</p>
- </div>
- </div>
- </a-col>
- <a-col style="width: 20%" class="border-right">
- <div class="wrap">
- <div class="fr">
- <p class="title">访客平均访问页面数</p>
- <p style="font-size: 25px">{{ averageVisitPage }}</p>
- </div>
- </div>
- </a-col>
- <a-col style="width: 20%" class="border-right">
- <div class="wrap">
- <div class="fr">
- <p class="title">跳出率</p>
- <p style="font-size: 25px">{{ bounceRate }}</p>
- </div>
- </div>
- </a-col>
- <a-col style="width: 20%">
- <div class="wrap">
- <div class="fr">
- <p class="title">UV到询盘转化率</p>
- <p style="font-size: 25px">{{ conversionRate }}</p>
- </div>
- </div>
- </a-col>
- </a-row>
- </a-row>
- </a-card>
- </a-col>
- </a-row>
- </div>
- </template>
- <script lang="ts" setup name="Adweb3Home">
- import areaChart from '/@/views/adweb/data/chart/areaChart.vue';
- import { getAction } from '/@/api/manage/manage';
- import { useUserStore } from '/@/store/modules/user';
- import selectSite from '/@/components/Adweb/selectSite.vue';
- import '/@/assets/less/home.less';
- import { useMessage } from '/@/hooks/web/useMessage';
- import { onMounted, reactive, ref } from 'vue';
- const { createMessage } = useMessage();
- const columns = [
- {
- title: '指标',
- dataIndex: 'targetName',
- },
- {
- title: '今日',
- dataIndex: 'todayCount',
- },
- {
- title: '昨日',
- dataIndex: 'yesterdayCount',
- scopedSlots: { customRender: 'yesterdayCount' },
- },
- {
- title: '本周',
- dataIndex: 'currentWeekCount',
- scopedSlots: { customRender: 'currentWeekCount' },
- },
- {
- title: '上周',
- dataIndex: 'lastWeekCount',
- },
- {
- title: '本月',
- dataIndex: 'currentMonthCount',
- },
- {
- title: '上月',
- dataIndex: 'lastMonthCount',
- },
- {
- title: '全部',
- dataIndex: 'totalCount',
- },
- ];
- const userRole = ref('');
- const timeChooseIndex = ref(7);
- //网站概况
- const siteDomain = ref('');
- const siteCode = ref('');
- const siteStatus = ref(0);
- let baseInfo = reactive<any>({});
- const baseInfoLoading = ref(false);
- //物料完成情况
- // TODO
- //核心数据
- const coreInfoLoading = ref(false);
- const coreDetailLoading = ref(false);
- const chartsLoading = ref(false);
- const achievePercent = ref(0);
- const appointWordCount = ref(0);
- const currentAchieveCount = ref(0);
- const currentMonthEnquiryCount = ref(0);
- const currentWeekEnquiryCount = ref(0);
- const totalEnquiryCount = ref(0);
- let flowIndicator = ref({});
- let coreDataTable = ref([]);
- const coreDataChart = ref({
- x: [],
- uv: [],
- pv: [],
- enquiry: [],
- });
- const averageVisit = ref(0);
- const averageVisitDuration = ref(0);
- const averageVisitPage = ref(0);
- const bounceRate = ref(0);
- const conversionRate = ref(0);
- const isShow = ref(false);
- onMounted(() => {
- userRole.value = useUserStore().roleList;
- });
- //改变站点
- function changeUser(selectedParamSiteInfo: any) {
- siteCode.value = selectedParamSiteInfo.code;
- siteDomain.value = selectedParamSiteInfo.domain;
- siteStatus.value = selectedParamSiteInfo.status;
- getAllInfo();
- }
- function filter_Null_format(value) {
- if (value === '' || value === null || value === undefined) {
- return '--';
- } else {
- return value;
- }
- }
- //保证先获取到站点列表,获取到siteCode及siteId后再进行此方法
- function getAllInfo() {
- getBaseInfo();
- getCoreData();
- getCoreDataChart();
- }
- //获取基础信息
- function getBaseInfo() {
- let d = {
- siteCode: siteCode.value,
- };
- baseInfoLoading.value = true;
- getAction('/adweb/adwebSiteManage/siteBasicInfo', d).then(function (res) {
- baseInfoLoading.value = false;
- if (res.code == 200) {
- baseInfo = res.result;
- isShow.value = true;
- } else {
- createMessage.error('获取站点基础信息失败,请刷新重试');
- }
- });
- }
- const yesterdayData = ref({});
- const todayData = ref({});
- const thisWeekData = ref({});
- const lastWeekData = ref({});
- const thisMonthData = ref({});
- const lastMonthData = ref({});
- const allTimeData = ref({});
- //获取核心数据
- function getCoreData() {
- let d = {
- siteCode: siteCode.value,
- };
- coreInfoLoading.value = true;
- getAction('/dmp-data/site-periodic/stats', d).then(function (res) {
- coreInfoLoading.value = false;
- if (res.code == 200) {
- yesterdayData.value = res.result.yesterday;
- todayData.value = res.result.today;
- thisWeekData.value = res.result.thisWeek;
- lastWeekData.value = res.result.lastWeek;
- thisMonthData.value = res.result.thisMonth;
- lastMonthData.value = res.result.lastMonth;
- allTimeData.value = res.result.allTime;
- // achievePercent.value = res.data.achievePercent;
- // appointWordCount.value = res.data.appointWordCount;
- // currentAchieveCount.value = res.data.currentAchieveCount;
- // currentMonthEnquiryCount.value = res.data.currentMonthEnquiryCount;
- // currentWeekEnquiryCount.value = res.data.currentWeekEnquiryCount;
- // totalEnquiryCount.value = res.data.totalEnquiryCount;
- // flowIndicator = res.data.flowIndicator;
- currentWeekEnquiryCount.value = thisWeekData.value.enquires;
- currentMonthEnquiryCount.value = thisMonthData.value.enquires;
- totalEnquiryCount.value = allTimeData.value.enquires;
- coreDataTable.value = [];
- coreDataTable.value.push(
- {
- targetName: '访客数(UV)',
- todayCount: todayData.value.totalUsers,
- yesterdayCount: yesterdayData.value.totalUsers,
- currentWeekCount: thisWeekData.value.totalUsers,
- lastWeekCount: lastWeekData.value.totalUsers,
- currentMonthCount: thisMonthData.value.totalUsers,
- lastMonthCount: lastMonthData.value.totalUsers,
- totalCount: allTimeData.value.totalUsers,
- },
- {
- targetName: '访问量(PV)',
- todayCount: todayData.value.pageViews,
- yesterdayCount: yesterdayData.value.pageViews,
- currentWeekCount: thisWeekData.value.pageViews,
- lastWeekCount: lastWeekData.value.pageViews,
- currentMonthCount: thisMonthData.value.pageViews,
- lastMonthCount: lastMonthData.value.pageViews,
- totalCount: allTimeData.value.pageViews,
- },
- {
- targetName: '询盘数',
- todayCount: todayData.value.enquires,
- yesterdayCount: yesterdayData.value.enquires,
- currentWeekCount: thisWeekData.value.enquires,
- lastWeekCount: lastWeekData.value.enquires,
- currentMonthCount: thisMonthData.value.enquires,
- lastMonthCount: lastMonthData.value.enquires,
- totalCount: allTimeData.value.enquires,
- },
- {
- targetName: '询盘转化率',
- todayCount: todayData.value.enquiryConversionRate,
- yesterdayCount: yesterdayData.value.enquiryConversionRate,
- currentWeekCount: thisWeekData.value.enquiryConversionRate,
- lastWeekCount: lastWeekData.value.enquiryConversionRate,
- currentMonthCount: thisMonthData.value.enquiryConversionRate,
- lastMonthCount: lastMonthData.value.enquiryConversionRate,
- totalCount: allTimeData.value.enquiryConversionRate,
- }
- );
- } else {
- createMessage.error('获取核心数据信息失败,请刷新重试');
- }
- });
- }
- //改变图表的时间维度
- function changeTime(time) {
- console.log(time);
- timeChooseIndex.value = time;
- getCoreDataChart();
- }
- //核心数据的面积图
- const getCoreDataChart = async () => {
- let d = {
- siteCode: siteCode.value,
- dateType: timeChooseIndex.value,
- };
- chartsLoading.value = true;
- const res = await getAction('/dmp-data/site-overview/stats', d);
- if (res.code == 200) {
- let r = res.result == null ? {} : res.result;
- averageVisit.value = r.dailyTotalUsers == null ? '0' : r.dailyTotalUsers;
- averageVisitDuration.value = r.avgTimeOnPage == null ? '0' : r.avgTimeOnPage;
- averageVisitPage.value = r.pageViewsPerSession == null ? '0' : r.pageViewsPerSession;
- bounceRate.value = r.bounceRate == null ? '0' : r.bounceRate;
- conversionRate.value = r.enquiryConversionRate == null ? '0' : r.enquiryConversionRate;
- let x = [],
- pv = [],
- uv = [],
- enquiry = [];
- if (r.dailyStats != null && r.dailyStats.length > 0) {
- for (let i in r.dailyStats) {
- x.push(r.dailyStats[i].date);
- pv.push(r.dailyStats[i].pageViews);
- uv.push(r.dailyStats[i].totalUsers);
- enquiry.push(r.dailyStats[i].enquires);
- }
- }
- coreDataChart.value.x = x;
- coreDataChart.value.pv = pv;
- coreDataChart.value.uv = uv;
- coreDataChart.value.enquiry = enquiry;
- } else {
- averageVisit.value = 0;
- averageVisitDuration.value = 0;
- averageVisitPage.value = 0;
- bounceRate.value = 0;
- coreDataChart.value.x = [];
- coreDataChart.value.pv = [];
- coreDataChart.value.uv = [];
- coreDataChart.value.enquiry = [];
- createMessage.error('获取核心数据图表信息失败,请刷新重试');
- }
- chartsLoading.value = false;
- };
- </script>
- <style lang="less">
- .home {
- .ant-select {
- color: #fff;
- .ant-select-selection {
- background-color: transparent;
- }
- .ant-select-arrow {
- color: #fff;
- }
- }
- }
- </style>
- <style scoped lang="less">
- p,
- span {
- color: #000;
- margin: 0;
- }
- .theme-color {
- color: @primary-color;
- }
- .title {
- font-size: 18px;
- color: #000;
- }
- </style>
- <style lang="less">
- .pop-wrap {
- .ant-popover-inner-content {
- padding: 0;
- }
- .wrap {
- width: 400px;
- padding: 20px 20px;
- background-position: bottom right;
- p {
- line-height: 1.8;
- i {
- color: @primary-color;
- margin-right: 10px;
- }
- }
- .name {
- font-size: 18px;
- margin-bottom: 20px;
- }
- .job {
- font-size: 15px;
- color: #9f9f9f;
- }
- .ant-col-8 {
- text-align: right;
- }
- }
- }
- .faban {
- .ant-modal {
- .ant-modal-content {
- background-color: transparent;
- box-shadow: none;
- .ant-modal-close {
- top: 70px;
- right: -10px;
- .ant-modal-close-x {
- width: auto;
- height: auto;
- }
- }
- .self-close {
- i {
- color: #fff;
- border: 1px solid #fff;
- width: 25px;
- height: 25px;
- display: block;
- line-height: 25px;
- }
- }
- .ant-modal-body {
- .top-bg {
- background: url('../../../../assets/home/faban/topbg.png') no-repeat;
- min-height: 242px;
- background-size: 100% 100%;
- display: flex;
- justify-content: center;
- align-items: flex-end;
- font-size: 38px;
- padding-bottom: 60px;
- p {
- color: #fff;
- }
- }
- .info-wrap {
- background: #fff;
- padding: 0 40px;
- overflow: hidden;
- border-bottom-left-radius: 15px;
- border-bottom-right-radius: 15px;
- margin-top: -1px;
- p {
- position: relative;
- padding-left: 30px;
- margin-bottom: 5px;
- letter-spacing: 1px;
- &:before {
- content: '';
- position: absolute;
- left: 0;
- width: 15px;
- height: 15px;
- background: url('../../../../assets/home/faban/dot.svg');
- background-repeat: no-repeat;
- top: 3px;
- }
- }
- img {
- width: 70px;
- float: right;
- padding: 40px 0;
- }
- }
- }
- }
- }
- }
- </style>
|