feat: 基础统计组件封装

This commit is contained in:
JiangQiming 2023-02-01 15:59:53 +08:00
parent 9c64386cc4
commit 59e4bacd74
3 changed files with 128 additions and 2 deletions

9
src/api/media/home.ts Normal file
View File

@ -0,0 +1,9 @@
import server from '@/utils/request'
export default {
// 设备数量
deviceCount: () => server.get<number>(`/media/device/_count`),
// 通道数量
channelCount: () => server.post<number>(`/media/channel/_count`),
}

View File

@ -0,0 +1,117 @@
<template>
<a-card class="device-count-container">
<template #title>
<h5 class="title">基础统计</h5>
</template>
<template #extra>
<span style="color: #1d39c4; cursor: pointer" @click="jumpPage"
>详情</span
>
</template>
<div class="box-list">
<div class="box-item">
<div class="label">设备数量</div>
<div class="value">{{ deviceCount }}</div>
<img src="/images/home/top-2.png" alt="" />
</div>
<div class="box-item">
<div class="label">通道数量</div>
<div class="value">{{ channelCount }}</div>
<img src="/images/home/top-1.png" alt="" />
</div>
</div>
</a-card>
</template>
<script setup lang="ts">
import homeApi from '@/api/media/home';
const channelCount = ref(0);
const deviceCount = ref(0);
onMounted(() => {
getData();
});
const getData = () => {
homeApi.deviceCount().then((resp) => {
deviceCount.value = resp.result;
});
homeApi.channelCount().then((resp) => {
channelCount.value = resp.result;
});
};
const router = useRouter();
const jumpPage = () => {
router.push('/media/dashboard');
};
</script>
<style lang="less" scoped>
.device-count-container {
:deep(.ant-card-body) {
padding-top: 0;
}
.title {
position: relative;
z-index: 2;
display: flex;
justify-content: space-between;
margin-bottom: 12px;
padding-left: 18px;
font-weight: 700;
font-size: 18px;
&::before {
position: absolute;
top: 50%;
left: 0;
width: 8px;
height: 8px;
background-color: #1d39c4;
border: 1px solid #b4c0da;
transform: translateY(-50%);
content: ' ';
}
}
.box-list {
display: grid;
grid-template-columns: repeat(2, 1fr);
grid-gap: 24px;
gap: 24px;
.box-item {
position: relative;
padding: 16px;
background: linear-gradient(
135.62deg,
#f6f7fd 22.27%,
hsla(0, 0%, 100%, 0.86) 91.82%
);
border-radius: 2px;
box-shadow: 0 4px 18px #efefef;
.label {
color: #4f4f4f;
}
.value {
margin: 20px 0;
color: rgba(0, 0, 0, 0.85);
font-weight: 700;
font-size: 20px;
}
img {
position: absolute;
right: 10%;
bottom: 0;
width: 90px;
height: 90px;
}
}
}
}
</style>

View File

@ -8,7 +8,7 @@
/> />
</a-col> </a-col>
<a-col :span="10"> <a-col :span="10">
<DeviceCountCard /> <BasicCountCard />
</a-col> </a-col>
<a-col :span="24" style="margin: 20px 0"> <a-col :span="24" style="margin: 20px 0">
<PlatformPicCard /> <PlatformPicCard />
@ -26,9 +26,9 @@
<script setup lang="ts"> <script setup lang="ts">
import BootCard from '@/views/home/components/BootCard.vue'; import BootCard from '@/views/home/components/BootCard.vue';
import DeviceCountCard from '@/views/home/components/DeviceCountCard.vue';
import PlatformPicCard from '@/views/home/components/PlatformPicCard.vue'; import PlatformPicCard from '@/views/home/components/PlatformPicCard.vue';
import StepCard from '@/views/home/components/StepCard.vue'; import StepCard from '@/views/home/components/StepCard.vue';
import BasicCountCard from '@/views/media/Home/components/BasicCountCard.vue';
import { usePermissionStore } from '@/store/permission'; import { usePermissionStore } from '@/store/permission';
import type { bootConfig, recommendList } from '@/views/home/index'; import type { bootConfig, recommendList } from '@/views/home/index';