Browse Source

首页返回旧版

wolyshaw 4 years ago
parent
commit
49824ef5b6
1 changed files with 256 additions and 32 deletions
  1. 256 32
      src/views/main/index.vue

+ 256 - 32
src/views/main/index.vue

@@ -1,46 +1,270 @@
 <template>
   <div class="m-container">
-    <h2>
-      <div class="squrt"></div>控制台
+    <h2 v-permission="'/main/main/allData/826'">
+      <div class="squrt"></div>首页
     </h2>
-    <div class="m-core">
-      <tab-router v-permission="'newIndex'">
-        <el-tab-pane lazy label="基本信息" name="baseinfo">
-          <baseinfo/>
-        </el-tab-pane>
-        <!-- <el-tab-pane lazy label="异常处理" name="abnormal">
-          <abnormal/>
-        </el-tab-pane>
-        <el-tab-pane lazy label="事项提醒" name="reminders">
-          <reminders/>
-        </el-tab-pane>
-        <el-tab-pane lazy label="【乐团主管】日程安排" name="teamSchedule">
-          <teamSchedule />
-        </el-tab-pane>
-        <el-tab-pane lazy label="【分部经理】日程安排" name="ScheduleBranch">
-          <ScheduleBranch/>
-        </el-tab-pane> -->
-      </tab-router>
+    <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 baseinfo from './baseinfo'
-// import abnormal from './abnormal'
-// import teamSchedule from './teamSchedule'
-// import ScheduleBranch from './schedule-branch'
-// import reminders from './reminders'
+import { getIndex } from '@/api/user'
 export default {
   name: 'Main',
-  components: {
-    baseinfo,
-    // abnormal,
-    // teamSchedule,
-    // ScheduleBranch,
-    // reminders,
+  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>