123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616 |
- <template>
- <div class="manage-root organize-manage">
- <Header />
- <div class="manage-root-contain">
- <nav-menu
- class="manage-root-contain-left"
- :activeMenuIndex="activeMenuIndex"
- ></nav-menu>
- <div class="manage-root-contain-right personnel-manage-right">
- <div class="top">
- <span>数据中心</span>
- <b>{{ queryTime }}</b>
- </div>
- <div class="day-stat-data" v-if="curDayStatData">
- <div class="day-item" v-if="curDayStatData.person_count">
- <div class="day-item-left">
- <p>用户总数</p>
- <span
- >{{ curDayStatData.person_count.total_count | formatNumber
- }}<b>人</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.person_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.person_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.person_count.add_count_pre_week > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.person_count.add_count_pre_week === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{ curDayStatData.person_count.add_count_pre_week }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.person_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.person_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.person_count.add_count_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.person_count.add_count_pre_month === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{ curDayStatData.person_count.add_count_pre_month }}</a>
- </span>
- </div>
- </div>
- <div class="day-item" v-if="curDayStatData.org_count">
- <div class="day-item-left">
- <p>机构总数</p>
- <span
- >{{ curDayStatData.org_count.total_count | formatNumber
- }}<b>个</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.org_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.org_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.org_count.add_count_pre_week > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.org_count.add_count_pre_week === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{ curDayStatData.org_count.add_count_pre_week }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.org_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.org_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.org_count.add_count_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.org_count.add_count_pre_month === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{ curDayStatData.org_count.add_count_pre_month }}</a>
- </span>
- </div>
- </div>
- <div class="day-item" v-if="curDayStatData.course_play_person_count">
- <div class="day-item-left">
- <p>累计上课人数</p>
- <span
- >{{
- curDayStatData.course_play_person_count.total_count
- | formatNumber
- }}<b>人</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.course_play_person_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.course_play_person_count
- .add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.course_play_person_count.add_count_pre_week >
- 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.course_play_person_count
- .add_count_pre_week === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.course_play_person_count.add_count_pre_week
- }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.course_play_person_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.course_play_person_count
- .add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.course_play_person_count
- .add_count_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.course_play_person_count
- .add_count_pre_month === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.course_play_person_count.add_count_pre_month
- }}</a>
- </span>
- </div>
- </div>
- <div class="day-item" v-if="curDayStatData.course_play_count">
- <div class="day-item-left">
- <p>累计上课人次</p>
- <span
- >{{ curDayStatData.course_play_count.total_count | formatNumber
- }}<b>人次</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.course_play_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.course_play_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.course_play_count.add_count_pre_week > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.course_play_count.add_count_pre_week ===
- 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{ curDayStatData.course_play_count.add_count_pre_week }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.course_play_count.add_count_pre_week > 0
- ? 'add'
- : curDayStatData.course_play_count.add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.course_play_count.add_count_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.course_play_count.add_count_pre_month ===
- 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.course_play_count.add_count_pre_month
- }}</a>
- </span>
- </div>
- </div>
- <div class="day-item" v-if="curDayStatData.article_reading_duration">
- <div class="day-item-left">
- <p>平台总阅读时长</p>
- <span
- >{{
- Math.ceil(
- curDayStatData.article_reading_duration.total_duration /
- 3600
- ) | formatNumber
- }}<b>时</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.article_reading_duration
- .add_duration_pre_week > 0
- ? 'add'
- : curDayStatData.article_reading_duration
- .add_duration_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.article_reading_duration
- .add_duration_pre_week > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.article_reading_duration
- .add_duration_pre_week === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.article_reading_duration.add_duration_pre_week
- }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.article_reading_duration
- .add_duration_pre_month > 0
- ? 'add'
- : curDayStatData.article_reading_duration
- .add_duration_pre_month === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.article_reading_duration
- .add_duration_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.article_reading_duration
- .add_duration_pre_month === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.article_reading_duration.add_duration_pre_month
- }}</a>
- </span>
- </div>
- </div>
- <div
- class="day-item"
- v-if="curDayStatData.article_reading_word_count"
- >
- <div class="day-item-left">
- <p>平台总阅读词数</p>
- <span
- >{{
- curDayStatData.article_reading_word_count.total_count
- | formatNumber
- }}<b>词</b></span
- >
- </div>
- <div class="day-item-center">
- <p>较上周</p>
- <span
- :class="[
- curDayStatData.article_reading_word_count.add_count_pre_week >
- 0
- ? 'add'
- : curDayStatData.article_reading_word_count
- .add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.article_reading_word_count
- .add_count_pre_week > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.article_reading_word_count
- .add_count_pre_week === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.article_reading_word_count.add_count_pre_week
- }}</a>
- </span>
- </div>
- <div class="day-item-right">
- <p>较上月</p>
- <span
- :class="[
- curDayStatData.article_reading_word_count.add_count_pre_week >
- 0
- ? 'add'
- : curDayStatData.article_reading_word_count
- .add_count_pre_week === 0
- ? 'flat'
- : 'down',
- ]"
- >
- <img
- :src="
- curDayStatData.article_reading_word_count
- .add_count_pre_month > 0
- ? require('../../assets/caret-up.png')
- : curDayStatData.article_reading_word_count
- .add_count_pre_month === 0
- ? require('../../assets/caret-flat.png')
- : require('../../assets/caret-down.png')
- "
- />
- <a>{{
- curDayStatData.article_reading_word_count.add_count_pre_month
- }}</a>
- </span>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </template>
- <script>
- //这里可以导入其它文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
- //例如:import 《组件名称》from ‘《组件路径》';
- import Header from "../../components/Header.vue";
- import NavMenu from "../../components/NavMenu.vue";
- import { getLogin } from "@/api/ajax";
- import { formatNumber } from "@/utils/defined";
- export default {
- //import引入的组件需要注入到对象中才能使用
- components: { Header, NavMenu },
- props: {},
- filters: {
- formatNumber,
- },
- data() {
- //这里存放数据
- return {
- activeMenuIndex: "data_center",
- tableHeight: "", // 表格高度
- tableLoading: false,
- queryTime: this.getCurrentDateTime(),
- curDayStatData: null, // 当日统计数据
- };
- },
- //计算属性 类似于data概念
- computed: {},
- //监控data中数据变化
- watch: {},
- //方法集合
- methods: {
- //计算table高度(动态设置table高度)
- getTableHeight() {
- let tableH = 420; //距离页面下方的高度
- let tableHeightDetil = window.innerHeight - tableH;
- if (tableHeightDetil <= 300) {
- this.tableHeight = 300;
- } else {
- this.tableHeight = window.innerHeight - tableH;
- }
- },
- // 获取数据
- getData() {
- // 得到当日统计数据
- let MethodName1 = "/ShopServer/Manager/DataStat/GetCurDayStatData";
- getLogin(MethodName1, {}).then((res) => {
- if (res.status === 1) {
- this.curDayStatData = res;
- }
- });
- // 统计用户区域分布(购买物品的用户)
- let MethodName2 =
- "/ShopServer/Manager/DataStat/StatUserAreaDistribution_BuyGoods";
- getLogin(MethodName2, {
- goods_type: -1,
- }).then((res) => {});
- // 统计每日人员数量
- let MethodName3 = "/ShopServer/Manager/DataStat/StatDailyPersonCount";
- let data1 = {
- province_id_list: ["01", "02"],
- city_id_list: ["0101", "0202"],
- begin_date: "2024-01-01",
- end_date: "2024-02-01",
- };
- getLogin(MethodName3, data1).then((res) => {});
- // 统计每日机构数量
- let MethodName4 = "/ShopServer/Manager/DataStat/StatDailyOrgCount";
- getLogin(MethodName4, data1).then((res) => {});
- // 统计每日累计上课人数
- let MethodName5 =
- "/ShopServer/Manager/DataStat/StatDailyAccCoursePlayPersonCount";
- getLogin(MethodName5, data1).then((res) => {});
- // 统计每日累计阅读时长
- let MethodName6 =
- "/ShopServer/Manager/DataStat/StatDailyAccArticleReadingDuration";
- getLogin(MethodName6, data1).then((res) => {});
- // 统计每日累计阅读词数
- let MethodName7 =
- "/ShopServer/Manager/DataStat/StatDailyAccArticleReadingWordCount";
- getLogin(MethodName7, data1).then((res) => {});
- // 统计每日累计上课人次
- let MethodName8 =
- "/ShopServer/Manager/DataStat/StatDailyAccCoursePlayCount";
- getLogin(MethodName8, data1).then((res) => {});
- },
- // 获取时间
- getCurrentDateTime() {
- const now = new Date();
- const year = now.getFullYear();
- const month = this.padNumber(now.getMonth() + 1); // 月份是从0开始的
- const day = this.padNumber(now.getDate());
- const hours = this.padNumber(now.getHours());
- const minutes = this.padNumber(now.getMinutes());
- return `${year}-${month}-${day} ${hours}:${minutes}`;
- },
- padNumber(num) {
- return num < 10 ? "0" + num : num;
- },
- },
- //生命周期 - 创建完成(可以访问当前this实例)
- created() {
- this.getTableHeight();
- this.getData();
- },
- //生命周期 - 挂载完成(可以访问DOM元素)
- mounted() {},
- //生命周期-创建之前
- beforeCreated() {},
- //生命周期-挂载之前
- beforeMount() {},
- //生命周期-更新之前
- beforUpdate() {},
- //生命周期-更新之后
- updated() {},
- //生命周期-销毁之前
- beforeDestory() {},
- //生命周期-销毁完成
- destoryed() {},
- //如果页面有keep-alive缓存功能,这个函数会触发
- activated() {},
- };
- </script>
- <style lang="scss" scoped>
- /* @import url(); 引入css类 */
- .manage-root-contain-right {
- padding-top: 24px;
- }
- .top {
- border-radius: 6px;
- background: #2460ff;
- padding: 20px 24px;
- display: flex;
- justify-content: space-between;
- color: #fff;
- font-weight: 500;
- align-items: center;
- span {
- font-size: 20px;
- line-height: 28px; /* 140% */
- }
- b {
- font-size: 12px;
- line-height: 20px; /* 166.667% */
- }
- }
- .day-stat-data {
- display: flex;
- gap: 16px;
- margin-top: 24px;
- flex-flow: wrap;
- .day-item {
- width: calc(50% - 8px);
- border-radius: 6px;
- background: #fff;
- flex-shrink: 0;
- display: flex;
- justify-content: space-between;
- padding: 16px 40px;
- column-gap: 24px;
- align-items: center;
- p {
- color: #4e5969;
- font-size: 12px;
- font-weight: 400;
- line-height: 20px;
- margin: 0;
- }
- .day-item-left {
- flex: 1;
- p {
- margin-bottom: 8px;
- }
- span {
- color: #1d2129;
- font-size: 22px;
- font-weight: 700;
- line-height: 24px;
- b {
- color: #4e5969;
- font-size: 12px;
- font-weight: 400;
- line-height: 20px;
- margin-left: 4px;
- }
- }
- }
- .day-item-center,
- .day-item-right {
- width: 80px;
- text-align: right;
- img {
- width: 16px;
- height: 16px;
- }
- a {
- font-size: 16px;
- font-weight: 600;
- line-height: 22px;
- }
- span {
- display: flex;
- justify-content: end;
- align-items: center;
- &.up {
- color: #fc4d42;
- }
- &.flat {
- color: #165dff;
- }
- &.down {
- color: #34b531;
- }
- }
- }
- }
- }
- </style>
|