| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- <template>
- <div class="m-container">
- <h2 v-permission="'/main/main/allData/826'">
- <div class="squrt"></div>首页
- </h2>
- <div class="m-core"
- v-permission="'/main/main/allData/826'">
- <div class="itemWrap">
- <div class="item">
- <h4>
- <p>分部乐团数</p> <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">全部</p>
- <p class='msg'> {{ dataInfo.mdTotal }}</p>
- </div>
- <div class="info">
- <p class="sub">筹备中</p>
- <p class='msg'>{{ dataInfo.prepare_num_ }}</p>
- </div>
- <div class="info">
- <p class="sub">进行中</p>
- <p class='msg'>{{ dataInfo.progress_num_ }}</p>
- </div>
- <div class="info">
- <p class="sub">已完成</p>
- <p class='msg'>{{ dataInfo.pause_num_ }}</p>
- </div>
- </div>
- </div>
- <!-- -->
- <div class="item"
- v-permission="'main/monthIncome'">
- <h4>
- <p>本月收入</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">收入笔数</p>
- <p class='msg'>{{ dataInfo.incomeMap && dataInfo.incomeMap.total >= 0 ? dataInfo.incomeMap.total : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">收入金额</p>
- <p class='msg'>{{ dataInfo.incomeMap && dataInfo.incomeMap.total_num_ >= 0 ? dataInfo.incomeMap.total_num_ : '--' }}</p>
- </div>
- </div>
- </div>
- <div class="item"
- v-permission="'main/monthExpenditure'">
- <h4>
- <p>本月支出</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">支出笔数</p>
- <p class='msg'>{{ dataInfo.incomeExpendMap && dataInfo.incomeExpendMap.expend_num_ >= 0 ? dataInfo.incomeExpendMap.expend_num_ : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">支出金额</p>
- <p class='msg'>{{ dataInfo.incomeExpendMap && dataInfo.incomeExpendMap.expend_total_ >= 0 ? dataInfo.incomeExpendMap.expend_total_ : '--' }}</p>
- </div>
- </div>
- </div>
- <div class="item">
- <h4>
- <p>分部老师数</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">总计</p>
- <p class='msg'>{{ dataInfo.teacherDatas && dataInfo.teacherDatas.total >= 0 ? dataInfo.teacherDatas.total : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">全职人数</p>
- <p class='msg'>{{ dataInfo.teacherDatas && dataInfo.teacherDatas.full_time_num_ >= 0 ? dataInfo.teacherDatas.full_time_num_ : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">兼职人数</p>
- <p class='msg'>{{ dataInfo.teacherDatas && dataInfo.teacherDatas.part_time_num_ >= 0 ? dataInfo.teacherDatas.part_time_num_ : '--' }}</p>
- </div>
- </div>
- </div>
- <div class="item">
- <h4>
- <p>VIP课数</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">总计</p>
- <p class='msg'>
- {{ dataInfo.vdTotal }}
- </p>
- </div>
- <div class="info">
- <p class="sub">进行中</p>
- <p class='msg'>{{ dataInfo.applying_num_ }}</p>
- </div>
- <div class="info">
- <p class="sub">已完成</p>
- <p class='msg'>{{ dataInfo.finished_num_ }}</p>
- </div>
- </div>
- </div>
- <div class="item">
- <h4>
- <p>试听课</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">总计</p>
- <p class='msg'>{{ dataInfo.ddTotal }}</p>
- </div>
- <div class="info">
- <p class="sub">已预约</p>
- <p class='msg'>{{ dataInfo.booked_num_ }}</p>
- </div>
- <div class="info">
- <p class="sub">未完成</p>
- <p class='msg'>{{ dataInfo.unbooked_num_ }}</p>
- </div>
- </div>
- </div>
- <div class="item">
- <h4>
- <p>分部学生数</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">总计</p>
- <p class='msg'>{{ dataInfo.studentDatas && dataInfo.studentDatas.total_num_ >= 0 ? dataInfo.studentDatas.total_num_ : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">本月新增</p>
- <p class='msg'>{{ dataInfo.studentDatas && dataInfo.studentDatas.new_num_ >= 0 ? dataInfo.studentDatas.new_num_ : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">本月退团</p>
- <p class='msg'>{{ dataInfo.studentDatas && dataInfo.studentDatas.quit_num_ >= 0 ? dataInfo.studentDatas.quit_num_ : '--' }}</p>
- </div>
- </div>
- </div>
- <div class="item">
- <h4>
- <p>本月预计上课</p>
- <img src=""
- alt="">
- </h4>
- <div class="infos">
- <div class="info">
- <p class="sub">乐团课</p>
- <p class='msg'>{{ dataInfo.musicGroupNum >= 0 ? dataInfo.musicGroupNum : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">VIP课</p>
- <p class='msg'>{{ dataInfo.vipGroupNum >= 0 ? dataInfo.vipGroupNum : '--' }}</p>
- </div>
- <div class="info">
- <p class="sub">试听课</p>
- <p class='msg'>{{ dataInfo.demoGroupNum >= 0 ? dataInfo.demoGroupNum : '--' }}</p>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </template>
- <script>
- import { getIndex } from '@/api/user'
- export default {
- name: 'Main',
- data () {
- return {
- dataInfo: {}
- }
- },
- mounted () {
- this.__init();
- },
- methods: {
- __init () {
- getIndex().then(res => {
- if (res.code == 200) {
- // this.dataInfo = res.data
- let md = res.data.musicDatas || {},
- vd = res.data.vipDatas || {},
- dd = res.data.demoDatas || {}
- let tempDate = {
- mdTotal: (md.progress_num_ ? md.progress_num_ : 0) + (md.prepare_num_ ? md.prepare_num_ : 0) + (md.pause_num_ ? md.pause_num_ : 0),
- progress_num_: md.progress_num_ >= 0 ? md.progress_num_ : '--',
- prepare_num_: md.prepare_num_ >= 0 ? md.prepare_num_ : '--',
- pause_num_: md.pause_num_ >= 0 ? md.pause_num_ : '--',
- vdTotal: (vd.finished_num_ ? vd.finished_num_ : 0) + (vd.applying_num_ ? vd.applying_num_ : 0),
- finished_num_: vd.finished_num_ >= 0 ? vd.finished_num_ : '--',
- applying_num_: vd.applying_num_ >= 0 ? vd.applying_num_ : '--',
- ddTotal: (dd.booked_num_ ? dd.booked_num_ : 0) + (dd.unbooked_num_ ? dd.unbooked_num_ : 0),
- booked_num_: dd.booked_num_ >= 0 ? dd.booked_num_ : '--',
- unbooked_num_: dd.unbooked_num_ >= 0 ? dd.unbooked_num_ : '--'
- }
- this.dataInfo = Object.assign(res.data, tempDate)
- }
- })
- }
- }
- }
- </script>
- <style lang="scss" scope>
- .itemWrap {
- display: flex;
- flex-direction: row;
- justify-content: flex-start;
- align-items: center;
- flex-wrap: wrap;
- .item {
- width: 333px;
- height: 137px;
- padding: 22px 28px 20px;
- box-shadow: 0px 8px 20px 0px rgba(0, 0, 0, 0.1);
- border-radius: 6px;
- margin: 0 15px 3rem;
- h4 {
- display: flex;
- flex-direction: row;
- justify-content: space-between;
- margin-bottom: 20px;
- color: #323c47;
- font-size: 14px;
- }
- .infos {
- display: flex;
- flex-direction: row;
- justify-content: space-between;
- .sub {
- font-size: 14px;
- line-height: 20px;
- color: #aaa;
- margin-bottom: 8px;
- }
- .msg {
- font-size: 24px;
- font-weight: 500;
- color: rgba(68, 68, 68, 1);
- line-height: 28px;
- text-align: center;
- }
- }
- }
- }
- </style>
|