feat(dashborad): 完善仪表盘

This commit is contained in:
Coffee-crocodile 2023-01-09 18:07:43 +08:00
parent 9eff695622
commit 264cc119cb
3 changed files with 156 additions and 67 deletions

33
.vscode/settings.json vendored
View File

@ -1,20 +1,17 @@
{ {
// //
// "workbench.colorTheme": "Atom One Light", "editor.tabSize": 2,
// // eslint
"editor.tabSize": 2, "editor.codeActionsOnSave": {
// eslint "source.fixAll.eslint": true
"editor.codeActionsOnSave": { },
"source.fixAll.eslint": true "eslint.format.enable": true,
}, //
"eslint.format.enable": true, "eslint.validate": ["typescript", "javascript", "vue", "html"],
// //
"eslint.validate": ["typescript", "javascript", "vue", "html"], "eslint.alwaysShowStatus": true,
"nuxt.isNuxtApp": false, //
// "eslint.options": { "configFile": ".eslintrc.js" },
"eslint.alwaysShowStatus": true, //
// "editor.formatOnSave": true
"eslint.options": { "configFile": ".eslintrc.js" },
//
"editor.formatOnSave": true,
} }

View File

@ -17,7 +17,7 @@
"dev:prod": "cross-env VITE_SERVICE_ENV=prod vite", "dev:prod": "cross-env VITE_SERVICE_ENV=prod vite",
"build": "vue-tsc --noEmit && vite build", "build": "vue-tsc --noEmit && vite build",
"preview": "vite preview", "preview": "vite preview",
"lint": "eslint . --ext .vue,.js,.jsx,.cjs,.mjs,.ts,.tsx,.cts,.mts,.json --fix", "lint": "eslint . --fix",
"prepare": "husky install", "prepare": "husky install",
"commit": "cz", "commit": "cz",
"changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md" "changelog": "conventional-changelog -p angular -i CHANGELOG.md -s -r 0 && git add CHANGELOG.md"

View File

@ -1,83 +1,159 @@
<template> <template>
<div> <div>
<n-grid :x-gap="16" :y-gap="16"> <n-grid
:x-gap="16"
:y-gap="16"
>
<n-gi :span="6"> <n-gi :span="6">
<n-card> <n-card>
<n-space justify="space-between" align="center"> <n-space
justify="space-between"
align="center"
>
<n-statistic label="访问量"> <n-statistic label="访问量">
<n-number-animation ref="numberAnimationInstRef" :from="0" :to="12039" show-separator /> <n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="12039"
show-separator
/>
</n-statistic> </n-statistic>
<n-icon color="#de4307" size="42"> <n-icon
color="#de4307"
size="42"
>
<i-icon-park-outline-chart-histogram /> <i-icon-park-outline-chart-histogram />
</n-icon> </n-icon>
</n-space> </n-space>
<template #footer> <template #footer>
<n-space justify="space-between"> <n-space justify="space-between">
<span>累计访问数</span> <span>累计访问数</span>
<span><n-number-animation ref="numberAnimationInstRef" :from="0" :to="322039" show-separator /></span> <span><n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="322039"
show-separator
/></span>
</n-space> </n-space>
</template> </template>
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi :span="6"> <n-gi :span="6">
<n-card> <n-card>
<n-space justify="space-between" align="center"> <n-space
justify="space-between"
align="center"
>
<n-statistic label="下载量"> <n-statistic label="下载量">
<n-number-animation ref="numberAnimationInstRef" :from="0" :to="12039" show-separator /> <n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="12039"
show-separator
/>
</n-statistic> </n-statistic>
<n-icon color="#ffb549" size="42"> <n-icon
color="#ffb549"
size="42"
>
<i-icon-park-outline-chart-graph /> <i-icon-park-outline-chart-graph />
</n-icon> </n-icon>
</n-space> </n-space>
<template #footer> <template #footer>
<n-space justify="space-between"> <n-space justify="space-between">
<span>累计下载量</span> <span>累计下载量</span>
<span><n-number-animation ref="numberAnimationInstRef" :from="0" :to="322039" show-separator /></span> <span><n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="322039"
show-separator
/></span>
</n-space> </n-space>
</template> </template>
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi :span="6"> <n-gi :span="6">
<n-card> <n-card>
<n-space justify="space-between" align="center"> <n-space
justify="space-between"
align="center"
>
<n-statistic label="浏览量"> <n-statistic label="浏览量">
<n-number-animation ref="numberAnimationInstRef" :from="0" :to="12039" show-separator /> <n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="12039"
show-separator
/>
</n-statistic> </n-statistic>
<n-icon color="#1687a7" size="42"> <n-icon
color="#1687a7"
size="42"
>
<i-icon-park-outline-average /> <i-icon-park-outline-average />
</n-icon> </n-icon>
</n-space> </n-space>
<template #footer> <template #footer>
<n-space justify="space-between"> <n-space justify="space-between">
<span>累计浏览量</span> <span>累计浏览量</span>
<span><n-number-animation ref="numberAnimationInstRef" :from="0" :to="322039" show-separator /></span> <span><n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="322039"
show-separator
/></span>
</n-space> </n-space>
</template> </template>
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi :span="6"> <n-gi :span="6">
<n-card> <n-card>
<n-space justify="space-between" align="center"> <n-space
justify="space-between"
align="center"
>
<n-statistic label="注册量"> <n-statistic label="注册量">
<n-number-animation ref="numberAnimationInstRef" :from="0" :to="12039" show-separator /> <n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="12039"
show-separator
/>
</n-statistic> </n-statistic>
<n-icon color="#42218E" size="42"> <n-icon
color="#42218E"
size="42"
>
<i-icon-park-outline-chart-pie /> <i-icon-park-outline-chart-pie />
</n-icon> </n-icon>
</n-space> </n-space>
<template #footer> <template #footer>
<n-space justify="space-between"> <n-space justify="space-between">
<span>累计注册量</span> <span>累计注册量</span>
<span><n-number-animation ref="numberAnimationInstRef" :from="0" :to="322039" show-separator /></span> <span><n-number-animation
ref="numberAnimationInstRef"
:from="0"
:to="322039"
show-separator
/></span>
</n-space> </n-space>
</template> </template>
</n-card> </n-card>
</n-gi> </n-gi>
<n-gi :span="24"> <n-gi :span="24">
<n-card content-style="padding: 0;"> <n-card content-style="padding: 0;">
<n-tabs type="line" size="large" :tabs-padding="20" pane-style="padding: 20px;"> <n-tabs
<n-tab-pane name="流量趋势">流量趋势</n-tab-pane> type="line"
<n-tab-pane name="访问量趋势">访问量趋势</n-tab-pane> size="large"
:tabs-padding="20"
pane-style="padding: 20px;"
>
<n-tab-pane name="流量趋势">
流量趋势
</n-tab-pane>
<n-tab-pane name="访问量趋势">
访问量趋势
</n-tab-pane>
</n-tabs> </n-tabs>
</n-card> </n-card>
</n-gi> </n-gi>
@ -98,8 +174,18 @@
content: true, content: true,
}" }"
> >
<template #header-extra><n-button type="primary" quaternary>更多</n-button></template> <template #header-extra>
<n-table :bordered="false" :single-line="false"> <n-button
type="primary"
quaternary
>
更多
</n-button>
</template>
<n-table
:bordered="false"
:single-line="false"
>
<thead> <thead>
<tr> <tr>
<th>交易名称</th> <th>交易名称</th>
@ -110,13 +196,19 @@
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr v-for="item in tableData" :key="item.id"> <tr
v-for="item in tableData"
:key="item.id"
>
<td>{{ item.name }}</td> <td>{{ item.name }}</td>
<td>{{ item.start }}</td> <td>{{ item.start }}</td>
<td>{{ item.end }}</td> <td>{{ item.end }}</td>
<td>{{ item.prograss }}%</td> <td>{{ item.prograss }}%</td>
<td> <td>
<n-tag :bordered="false" type="info"> <n-tag
:bordered="false"
type="info"
>
{{ item.status }} {{ item.status }}
</n-tag> </n-tag>
</td> </td>
@ -131,30 +223,30 @@
<script setup lang="ts"> <script setup lang="ts">
const tableData = [ const tableData = [
{ {
id: 0, id: 0,
name: '商品名称1', name: '商品名称1',
start: '2022-02-02', start: '2022-02-02',
end: '2022-02-02', end: '2022-02-02',
prograss: '100', prograss: '100',
status: '已完成', status: '已完成',
}, },
{ {
id: 0, id: 0,
name: '商品名称2', name: '商品名称2',
start: '2022-02-02', start: '2022-02-02',
end: '2022-02-02', end: '2022-02-02',
prograss: '50', prograss: '50',
status: '交易中', status: '交易中',
}, },
{ {
id: 0, id: 0,
name: '商品名称3', name: '商品名称3',
start: '2022-02-02', start: '2022-02-02',
end: '2022-02-02', end: '2022-02-02',
prograss: '100', prograss: '100',
status: '已完成', status: '已完成',
}, },
]; ];
</script> </script>